jdk/src/share/classes/sun/font/TrueTypeFont.java
author prr
Thu, 02 Apr 2009 10:16:53 -0700
changeset 2693 f87942d1edba
parent 1721 7a86d7e13fdf
child 2699 4cc60e987b67
permissions -rw-r--r--
6753173: No need to read all the TrueType 'post' table to get underline info Reviewed-by: igor, jgodinez
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
715
f16baef3a20e 6719955: Update copyright year
xdono
parents: 550
diff changeset
     2
 * Copyright 2003-2008 Sun Microsystems, Inc.  All Rights Reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Sun designates this
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 * by Sun in the LICENSE file that accompanied this code.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 * CA 95054 USA or visit www.sun.com if you need additional information or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
 * have any questions.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
package sun.font;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
import java.awt.Font;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
import java.awt.FontFormatException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
import java.awt.GraphicsEnvironment;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
import java.awt.geom.Point2D;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
import java.io.FileNotFoundException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
import java.io.IOException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
import java.io.RandomAccessFile;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
import java.io.UnsupportedEncodingException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
import java.nio.ByteBuffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
import java.nio.CharBuffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
import java.nio.IntBuffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
import java.nio.ShortBuffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
import java.nio.channels.ClosedChannelException;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
import java.nio.channels.FileChannel;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
import java.util.HashSet;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
import java.util.Locale;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
import java.util.logging.Level;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
import sun.java2d.Disposer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
import sun.java2d.DisposerRecord;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
 * TrueTypeFont is not called SFntFont because it is not expected
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
 * to handle all types that may be housed in a such a font file.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
 * If additional types are supported later, it may make sense to
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
 * create an SFnt superclass. Eg to handle sfnt-housed postscript fonts.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
 * OpenType fonts are handled by this class, and possibly should be
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
 * represented by a subclass.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
 * An instance stores some information from the font file to faciliate
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
 * faster access. File size, the table directory and the names of the font
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
 * are the most important of these. It amounts to approx 400 bytes
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
 * for a typical font. Systems with mutiple locales sometimes have up to 400
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
 * font files, and an app which loads all font files would need around
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
 * 160Kbytes. So storing any more info than this would be expensive.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
public class TrueTypeFont extends FileFont {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
   /* -- Tags for required TrueType tables */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
    public static final int cmapTag = 0x636D6170; // 'cmap'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
    public static final int glyfTag = 0x676C7966; // 'glyf'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
    public static final int headTag = 0x68656164; // 'head'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
    public static final int hheaTag = 0x68686561; // 'hhea'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
    public static final int hmtxTag = 0x686D7478; // 'hmtx'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
    public static final int locaTag = 0x6C6F6361; // 'loca'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
    public static final int maxpTag = 0x6D617870; // 'maxp'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
    public static final int nameTag = 0x6E616D65; // 'name'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
    public static final int postTag = 0x706F7374; // 'post'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
    public static final int os_2Tag = 0x4F532F32; // 'OS/2'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
    /* -- Tags for opentype related tables */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
    public static final int GDEFTag = 0x47444546; // 'GDEF'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
    public static final int GPOSTag = 0x47504F53; // 'GPOS'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
    public static final int GSUBTag = 0x47535542; // 'GSUB'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
    public static final int mortTag = 0x6D6F7274; // 'mort'
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
    /* -- Tags for non-standard tables */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
    public static final int fdscTag = 0x66647363; // 'fdsc' - gxFont descriptor
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
    public static final int fvarTag = 0x66766172; // 'fvar' - gxFont variations
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
    public static final int featTag = 0x66656174; // 'feat' - layout features
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
    public static final int EBLCTag = 0x45424C43; // 'EBLC' - embedded bitmaps
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
    public static final int gaspTag = 0x67617370; // 'gasp' - hint/smooth sizes
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
    /* --  Other tags */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
    public static final int ttcfTag = 0x74746366; // 'ttcf' - TTC file
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
    public static final int v1ttTag = 0x00010000; // 'v1tt' - Version 1 TT font
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
    public static final int trueTag = 0x74727565; // 'true' - Version 2 TT font
1716
461122becab9 4356282: RFE: T2K should be used to rasterize CID/CFF fonts
igor
parents: 550
diff changeset
    93
    public static final int ottoTag = 0x4f54544f; // 'otto' - OpenType font
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
    /* -- ID's used in the 'name' table */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
    public static final int MS_PLATFORM_ID = 3;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
    /* MS locale id for US English is the "default" */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
    public static final short ENGLISH_LOCALE_ID = 0x0409; // 1033 decimal
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
    public static final int FAMILY_NAME_ID = 1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
    // public static final int STYLE_WEIGHT_ID = 2; // currently unused.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
    public static final int FULL_NAME_ID = 4;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
    public static final int POSTSCRIPT_NAME_ID = 6;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
    class DirectoryEntry {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
        int tag;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
        int offset;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
        int length;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
    /* There is a pool which limits the number of fd's that are in
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
     * use. Normally fd's are closed as they are replaced in the pool.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
     * But if an instance of this class becomes unreferenced, then there
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
     * needs to be a way to close the fd. A finalize() method could do this,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
     * but using the Disposer class will ensure its called in a more timely
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
     * manner. This is not something which should be relied upon to free
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
     * fd's - its a safeguard.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
    private static class TTDisposerRecord implements DisposerRecord {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
        FileChannel channel = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
90ce3da70b43 Initial load
duke
parents:
diff changeset
   123
        public synchronized void dispose() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   124
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   125
                if (channel != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
                    channel.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
            } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
            } finally {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
                channel = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
    TTDisposerRecord disposerRecord = new TTDisposerRecord();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
    /* > 0 only if this font is a part of a collection */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
    int fontIndex = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
    /* Number of fonts in this collection. ==1 if not a collection */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
    int directoryCount = 1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
    /* offset in file of table directory for this font */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
    int directoryOffset; // 12 if its not a collection.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
    /* number of table entries in the directory/offsets table */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
    int numTables;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
    /* The contents of the the directory/offsets table */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
    DirectoryEntry []tableDirectory;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
//     protected byte []gposTable = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
//     protected byte []gdefTable = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
//     protected byte []gsubTable = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
//     protected byte []mortTable = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
//     protected boolean hintsTabledChecked = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
//     protected boolean containsHintsTable = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
    /* These fields are set from os/2 table info. */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
    private boolean supportsJA;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
    private boolean supportsCJK;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
     * - does basic verification of the file
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
     * - reads the header table for this font (within a collection)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
     * - reads the names (full, family).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
     * - determines the style of the font.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
     * - initializes the CMAP
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
     * @throws FontFormatException - if the font can't be opened
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
     * or fails verification,  or there's no usable cmap
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
    TrueTypeFont(String platname, Object nativeNames, int fIndex,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
                 boolean javaRasterizer)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
        throws FontFormatException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
        super(platname, nativeNames);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
        useJavaRasterizer = javaRasterizer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
        fontRank = Font2D.TTF_RANK;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
        verify();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
        init(fIndex);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
        Disposer.addObjectRecord(this, disposerRecord);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
    /* Enable natives just for fonts picked up from the platform that
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
     * may have external bitmaps on Solaris. Could do this just for
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
     * the fonts that are specified in font configuration files which
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
     * would lighten the burden (think about that).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
     * The EBLCTag is used to skip natives for fonts that contain embedded
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
     * bitmaps as there's no need to use X11 for those fonts.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
     * Skip all the latin fonts as they don't need this treatment.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
     * Further refine this to fonts that are natively accessible (ie
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
     * as PCF bitmap fonts on the X11 font path).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
     * This method is called when creating the first strike for this font.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
    protected boolean checkUseNatives() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
        if (checkedNatives) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   196
            return useNatives;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
        if (!FontManager.isSolaris || useJavaRasterizer ||
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
            FontManager.useT2K || nativeNames == null ||
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
            getDirectoryEntry(EBLCTag) != null ||
90ce3da70b43 Initial load
duke
parents:
diff changeset
   201
            GraphicsEnvironment.isHeadless()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   202
            checkedNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   203
            return false; /* useNatives is false */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   204
        } else if (nativeNames instanceof String) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   205
            String name = (String)nativeNames;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   206
            /* Don't do do this for Latin fonts */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   207
            if (name.indexOf("8859") > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
                checkedNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   209
                return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   210
            } else if (NativeFont.hasExternalBitmaps(name)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   211
                nativeFonts = new NativeFont[1];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
                try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
                    nativeFonts[0] = new NativeFont(name, true);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   214
                    /* If reach here we have an non-latin font that has
90ce3da70b43 Initial load
duke
parents:
diff changeset
   215
                     * external bitmaps and we successfully created it.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   216
                     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   217
                    useNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   218
                } catch (FontFormatException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   219
                    nativeFonts = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   220
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   221
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
        } else if (nativeNames instanceof String[]) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   223
            String[] natNames = (String[])nativeNames;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
            int numNames = natNames.length;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
            boolean externalBitmaps = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   226
            for (int nn = 0; nn < numNames; nn++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   227
                if (natNames[nn].indexOf("8859") > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
                    checkedNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
                    return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
                } else if (NativeFont.hasExternalBitmaps(natNames[nn])) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
                    externalBitmaps = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
            if (!externalBitmaps) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
                checkedNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
                return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
            useNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   239
            nativeFonts = new NativeFont[numNames];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
            for (int nn = 0; nn < numNames; nn++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
                try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
                    nativeFonts[nn] = new NativeFont(natNames[nn], true);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
                } catch (FontFormatException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
                    useNatives = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
                    nativeFonts = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   246
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   247
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   248
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   249
        if (useNatives) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   250
            glyphToCharMap = new char[getMapper().getNumGlyphs()];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   252
        checkedNatives = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   253
        return useNatives;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   255
90ce3da70b43 Initial load
duke
parents:
diff changeset
   256
90ce3da70b43 Initial load
duke
parents:
diff changeset
   257
    /* This is intended to be called, and the returned value used,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   258
     * from within a block synchronized on this font object.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   259
     * ie the channel returned may be nulled out at any time by "close()"
90ce3da70b43 Initial load
duke
parents:
diff changeset
   260
     * unless the caller holds a lock.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
     * Deadlock warning: FontManager.addToPool(..) acquires a global lock,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
     * which means nested locks may be in effect.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   263
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
    private synchronized FileChannel open() throws FontFormatException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
        if (disposerRecord.channel == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   266
            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   267
                FontManager.logger.info("open TTF: " + platName);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   268
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   269
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
                RandomAccessFile raf = (RandomAccessFile)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
                java.security.AccessController.doPrivileged(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   272
                    new java.security.PrivilegedAction() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
                        public Object run() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   274
                            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
                                return new RandomAccessFile(platName, "r");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
                            } catch (FileNotFoundException ffne) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
                            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
                });
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
                disposerRecord.channel = raf.getChannel();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   282
                fileSize = (int)disposerRecord.channel.size();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
                FontManager.addToPool(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
            } catch (NullPointerException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
                close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
                throw new FontFormatException(e.toString());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
            } catch (ClosedChannelException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
                /* NIO I/O is interruptible, recurse to retry operation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
                 * The call to channel.size() above can throw this exception.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
                 * Clear interrupts before recursing in case NIO didn't.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
                 * Note that close() sets disposerRecord.channel to null.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
                 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
                Thread.interrupted();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
                close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
                open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
            } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
                close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
                throw new FontFormatException(e.toString());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   301
        return disposerRecord.channel;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   303
90ce3da70b43 Initial load
duke
parents:
diff changeset
   304
    protected synchronized void close() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
        disposerRecord.dispose();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
90ce3da70b43 Initial load
duke
parents:
diff changeset
   309
    int readBlock(ByteBuffer buffer, int offset, int length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
        int bread = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   311
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   312
            synchronized (this) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
                if (disposerRecord.channel == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   314
                    open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   315
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   316
                if (offset + length > fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   317
                    if (offset >= fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   318
                        /* Since the caller ensures that offset is < fileSize
90ce3da70b43 Initial load
duke
parents:
diff changeset
   319
                         * this condition suggests that fileSize is now
90ce3da70b43 Initial load
duke
parents:
diff changeset
   320
                         * different than the value we originally provided
90ce3da70b43 Initial load
duke
parents:
diff changeset
   321
                         * to native when the scaler was created.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   322
                         * Also fileSize is updated every time we
90ce3da70b43 Initial load
duke
parents:
diff changeset
   323
                         * open() the file here, but in native the value
90ce3da70b43 Initial load
duke
parents:
diff changeset
   324
                         * isn't updated. If the file has changed whilst we
90ce3da70b43 Initial load
duke
parents:
diff changeset
   325
                         * are executing we want to bail, not spin.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   326
                         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   327
                        if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   328
                            String msg = "Read offset is " + offset +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   329
                                " file size is " + fileSize+
90ce3da70b43 Initial load
duke
parents:
diff changeset
   330
                                " file is " + platName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   331
                            FontManager.logger.severe(msg);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   332
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   333
                        return -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   334
                    } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   335
                        length = fileSize - offset;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   336
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   337
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   338
                buffer.clear();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   339
                disposerRecord.channel.position(offset);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   340
                while (bread < length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   341
                    int cnt = disposerRecord.channel.read(buffer);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   342
                    if (cnt == -1) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   343
                        String msg = "Unexpected EOF " + this;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   344
                        int currSize = (int)disposerRecord.channel.size();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   345
                        if (currSize != fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   346
                            msg += " File size was " + fileSize +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   347
                                " and now is " + currSize;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   348
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   349
                        if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   350
                            FontManager.logger.severe(msg);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   351
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   352
                        // We could still flip() the buffer here because
90ce3da70b43 Initial load
duke
parents:
diff changeset
   353
                        // it's possible that we did read some data in
90ce3da70b43 Initial load
duke
parents:
diff changeset
   354
                        // an earlier loop, and we probably should
90ce3da70b43 Initial load
duke
parents:
diff changeset
   355
                        // return that to the caller. Although if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   356
                        // the caller expected 8K of data and we return
90ce3da70b43 Initial load
duke
parents:
diff changeset
   357
                        // only a few bytes then maybe it's better instead to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   358
                        // set bread = -1 to indicate failure.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   359
                        // The following is therefore using arbitrary values
90ce3da70b43 Initial load
duke
parents:
diff changeset
   360
                        // but is meant to allow cases where enough
90ce3da70b43 Initial load
duke
parents:
diff changeset
   361
                        // data was read to probably continue.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   362
                        if (bread > length/2 || bread > 16384) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   363
                            buffer.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   364
                            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   365
                                msg = "Returning " + bread +
90ce3da70b43 Initial load
duke
parents:
diff changeset
   366
                                    " bytes instead of " + length;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   367
                                FontManager.logger.severe(msg);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   368
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   369
                        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   370
                            bread = -1;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   371
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   372
                        throw new IOException(msg);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   373
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   374
                    bread += cnt;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   375
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   376
                buffer.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   377
                if (bread > length) { // possible if buffer.size() > length
90ce3da70b43 Initial load
duke
parents:
diff changeset
   378
                    bread = length;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   379
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   380
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   381
        } catch (FontFormatException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   382
            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   383
                FontManager.logger.log(Level.SEVERE,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   384
                                       "While reading " + platName, e);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   385
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   386
            bread = -1; // signal EOF
90ce3da70b43 Initial load
duke
parents:
diff changeset
   387
            deregisterFontAndClearStrikeCache();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   388
        } catch (ClosedChannelException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   389
            /* NIO I/O is interruptible, recurse to retry operation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   390
             * Clear interrupts before recursing in case NIO didn't.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   391
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   392
            Thread.interrupted();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   393
            close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   394
            return readBlock(buffer, offset, length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   395
        } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   396
            /* If we did not read any bytes at all and the exception is
90ce3da70b43 Initial load
duke
parents:
diff changeset
   397
             * not a recoverable one (ie is not ClosedChannelException) then
90ce3da70b43 Initial load
duke
parents:
diff changeset
   398
             * we should indicate that there is no point in re-trying.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   399
             * Other than an attempt to read past the end of the file it
90ce3da70b43 Initial load
duke
parents:
diff changeset
   400
             * seems unlikely this would occur as problems opening the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   401
             * file are handled as a FontFormatException.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   402
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   403
            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   404
                FontManager.logger.log(Level.SEVERE,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   405
                                       "While reading " + platName, e);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   406
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   407
            if (bread == 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   408
                bread = -1; // signal EOF
90ce3da70b43 Initial load
duke
parents:
diff changeset
   409
                deregisterFontAndClearStrikeCache();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   410
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   411
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   412
        return bread;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   413
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   414
90ce3da70b43 Initial load
duke
parents:
diff changeset
   415
    ByteBuffer readBlock(int offset, int length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   416
90ce3da70b43 Initial load
duke
parents:
diff changeset
   417
        ByteBuffer buffer = ByteBuffer.allocate(length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   418
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   419
            synchronized (this) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   420
                if (disposerRecord.channel == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   421
                    open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   422
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   423
                if (offset + length > fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   424
                    if (offset > fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   425
                        return null; // assert?
90ce3da70b43 Initial load
duke
parents:
diff changeset
   426
                    } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   427
                        buffer = ByteBuffer.allocate(fileSize-offset);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   428
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   429
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   430
                disposerRecord.channel.position(offset);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   431
                disposerRecord.channel.read(buffer);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   432
                buffer.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   433
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   434
        } catch (FontFormatException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   435
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   436
        } catch (ClosedChannelException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   437
            /* NIO I/O is interruptible, recurse to retry operation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   438
             * Clear interrupts before recursing in case NIO didn't.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   439
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   440
            Thread.interrupted();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   441
            close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   442
            readBlock(buffer, offset, length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   443
        } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   444
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   445
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   446
        return buffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   447
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   448
90ce3da70b43 Initial load
duke
parents:
diff changeset
   449
    /* This is used by native code which can't allocate a direct byte
90ce3da70b43 Initial load
duke
parents:
diff changeset
   450
     * buffer because of bug 4845371. It, and references to it in native
90ce3da70b43 Initial load
duke
parents:
diff changeset
   451
     * code in scalerMethods.c can be removed once that bug is fixed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   452
     * 4845371 is now fixed but we'll keep this around as it doesn't cost
90ce3da70b43 Initial load
duke
parents:
diff changeset
   453
     * us anything if its never used/called.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   454
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   455
    byte[] readBytes(int offset, int length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   456
        ByteBuffer buffer = readBlock(offset, length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   457
        if (buffer.hasArray()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   458
            return buffer.array();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   459
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   460
            byte[] bufferBytes = new byte[buffer.limit()];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   461
            buffer.get(bufferBytes);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   462
            return bufferBytes;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   463
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   464
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   465
90ce3da70b43 Initial load
duke
parents:
diff changeset
   466
    private void verify() throws FontFormatException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   467
        open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   468
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   469
90ce3da70b43 Initial load
duke
parents:
diff changeset
   470
    /* sizes, in bytes, of TT/TTC header records */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   471
    private static final int TTCHEADERSIZE = 12;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   472
    private static final int DIRECTORYHEADERSIZE = 12;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   473
    private static final int DIRECTORYENTRYSIZE = 16;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   474
90ce3da70b43 Initial load
duke
parents:
diff changeset
   475
    protected void init(int fIndex) throws FontFormatException  {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   476
        int headerOffset = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   477
        ByteBuffer buffer = readBlock(0, TTCHEADERSIZE);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   478
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   479
            switch (buffer.getInt()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   480
90ce3da70b43 Initial load
duke
parents:
diff changeset
   481
            case ttcfTag:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   482
                buffer.getInt(); // skip TTC version ID
90ce3da70b43 Initial load
duke
parents:
diff changeset
   483
                directoryCount = buffer.getInt();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   484
                if (fIndex >= directoryCount) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   485
                    throw new FontFormatException("Bad collection index");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   486
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   487
                fontIndex = fIndex;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   488
                buffer = readBlock(TTCHEADERSIZE+4*fIndex, 4);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   489
                headerOffset = buffer.getInt();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   490
                break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   491
90ce3da70b43 Initial load
duke
parents:
diff changeset
   492
            case v1ttTag:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   493
            case trueTag:
1716
461122becab9 4356282: RFE: T2K should be used to rasterize CID/CFF fonts
igor
parents: 550
diff changeset
   494
            case ottoTag:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   495
                break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   496
90ce3da70b43 Initial load
duke
parents:
diff changeset
   497
            default:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   498
                throw new FontFormatException("Unsupported sfnt " + platName);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   499
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   500
90ce3da70b43 Initial load
duke
parents:
diff changeset
   501
            /* Now have the offset of this TT font (possibly within a TTC)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   502
             * After the TT version/scaler type field, is the short
90ce3da70b43 Initial load
duke
parents:
diff changeset
   503
             * representing the number of tables in the table directory.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   504
             * The table directory begins at 12 bytes after the header.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   505
             * Each table entry is 16 bytes long (4 32-bit ints)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   506
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   507
            buffer = readBlock(headerOffset+4, 2);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   508
            numTables = buffer.getShort();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   509
            directoryOffset = headerOffset+DIRECTORYHEADERSIZE;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   510
            ByteBuffer bbuffer = readBlock(directoryOffset,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   511
                                           numTables*DIRECTORYENTRYSIZE);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   512
            IntBuffer ibuffer = bbuffer.asIntBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   513
            DirectoryEntry table;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   514
            tableDirectory = new DirectoryEntry[numTables];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   515
            for (int i=0; i<numTables;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   516
                tableDirectory[i] = table = new DirectoryEntry();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   517
                table.tag   =  ibuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   518
                /* checksum */ ibuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   519
                table.offset = ibuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   520
                table.length = ibuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   521
                if (table.offset + table.length > fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   522
                    throw new FontFormatException("bad table, tag="+table.tag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   523
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   524
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   525
            initNames();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   526
        } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   527
            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   528
                FontManager.logger.severe(e.toString());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   529
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   530
            if (e instanceof FontFormatException) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   531
                throw (FontFormatException)e;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   532
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   533
                throw new FontFormatException(e.toString());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   534
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   535
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   536
        if (familyName == null || fullName == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   537
            throw new FontFormatException("Font name not found");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   538
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   539
        /* The os2_Table is needed to gather some info, but we don't
90ce3da70b43 Initial load
duke
parents:
diff changeset
   540
         * want to keep it around (as a field) so obtain it once and
90ce3da70b43 Initial load
duke
parents:
diff changeset
   541
         * pass it to the code that needs it.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   542
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   543
        ByteBuffer os2_Table = getTableBuffer(os_2Tag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   544
        setStyle(os2_Table);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   545
        setCJKSupport(os2_Table);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   546
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   547
90ce3da70b43 Initial load
duke
parents:
diff changeset
   548
    /* The array index corresponds to a bit offset in the TrueType
90ce3da70b43 Initial load
duke
parents:
diff changeset
   549
     * font's OS/2 compatibility table's code page ranges fields.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   550
     * These are two 32 bit unsigned int fields at offsets 78 and 82.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   551
     * We are only interested in determining if the font supports
90ce3da70b43 Initial load
duke
parents:
diff changeset
   552
     * the windows encodings we expect as the default encoding in
90ce3da70b43 Initial load
duke
parents:
diff changeset
   553
     * supported locales, so we only map the first of these fields.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   554
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   555
    static final String encoding_mapping[] = {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   556
        "cp1252",    /*  0:Latin 1  */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   557
        "cp1250",    /*  1:Latin 2  */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   558
        "cp1251",    /*  2:Cyrillic */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   559
        "cp1253",    /*  3:Greek    */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   560
        "cp1254",    /*  4:Turkish/Latin 5  */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   561
        "cp1255",    /*  5:Hebrew   */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   562
        "cp1256",    /*  6:Arabic   */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   563
        "cp1257",    /*  7:Windows Baltic   */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   564
        "",          /*  8:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   565
        "",          /*  9:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   566
        "",          /* 10:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   567
        "",          /* 11:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   568
        "",          /* 12:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   569
        "",          /* 13:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   570
        "",          /* 14:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   571
        "",          /* 15:reserved for alternate ANSI */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   572
        "ms874",     /* 16:Thai     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   573
        "ms932",     /* 17:JIS/Japanese */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   574
        "gbk",       /* 18:PRC GBK Cp950  */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   575
        "ms949",     /* 19:Korean Extended Wansung */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   576
        "ms950",     /* 20:Chinese (Taiwan, Hongkong, Macau) */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   577
        "ms1361",    /* 21:Korean Johab */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   578
        "",          /* 22 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   579
        "",          /* 23 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   580
        "",          /* 24 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   581
        "",          /* 25 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   582
        "",          /* 26 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   583
        "",          /* 27 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   584
        "",          /* 28 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   585
        "",          /* 29 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   586
        "",          /* 30 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   587
        "",          /* 31 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   588
    };
90ce3da70b43 Initial load
duke
parents:
diff changeset
   589
90ce3da70b43 Initial load
duke
parents:
diff changeset
   590
    /* This maps two letter language codes to a Windows code page.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   591
     * Note that eg Cp1252 (the first subarray) is not exactly the same as
90ce3da70b43 Initial load
duke
parents:
diff changeset
   592
     * Latin-1 since Windows code pages are do not necessarily correspond.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   593
     * There are two codepages for zh and ko so if a font supports
90ce3da70b43 Initial load
duke
parents:
diff changeset
   594
     * only one of these ranges then we need to distinguish based on
90ce3da70b43 Initial load
duke
parents:
diff changeset
   595
     * country. So far this only seems to matter for zh.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   596
     * REMIND: Unicode locales such as Hindi do not have a code page so
90ce3da70b43 Initial load
duke
parents:
diff changeset
   597
     * this whole mechansim needs to be revised to map languages to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   598
     * the Unicode ranges either when this fails, or as an additional
90ce3da70b43 Initial load
duke
parents:
diff changeset
   599
     * validating test. Basing it on Unicode ranges should get us away
90ce3da70b43 Initial load
duke
parents:
diff changeset
   600
     * from needing to map to this small and incomplete set of Windows
90ce3da70b43 Initial load
duke
parents:
diff changeset
   601
     * code pages which looks odd on non-Windows platforms.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   602
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   603
    private static final String languages[][] = {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   604
90ce3da70b43 Initial load
duke
parents:
diff changeset
   605
        /* cp1252/Latin 1 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   606
        { "en", "ca", "da", "de", "es", "fi", "fr", "is", "it",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   607
          "nl", "no", "pt", "sq", "sv", },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   608
90ce3da70b43 Initial load
duke
parents:
diff changeset
   609
         /* cp1250/Latin2 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   610
        { "cs", "cz", "et", "hr", "hu", "nr", "pl", "ro", "sk",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   611
          "sl", "sq", "sr", },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   612
90ce3da70b43 Initial load
duke
parents:
diff changeset
   613
        /* cp1251/Cyrillic */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   614
        { "bg", "mk", "ru", "sh", "uk" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   615
90ce3da70b43 Initial load
duke
parents:
diff changeset
   616
        /* cp1253/Greek*/
90ce3da70b43 Initial load
duke
parents:
diff changeset
   617
        { "el" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   618
90ce3da70b43 Initial load
duke
parents:
diff changeset
   619
         /* cp1254/Turkish,Latin 5 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   620
        { "tr" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   621
90ce3da70b43 Initial load
duke
parents:
diff changeset
   622
         /* cp1255/Hebrew */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   623
        { "he" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   624
90ce3da70b43 Initial load
duke
parents:
diff changeset
   625
        /* cp1256/Arabic */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   626
        { "ar" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   627
90ce3da70b43 Initial load
duke
parents:
diff changeset
   628
         /* cp1257/Windows Baltic */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   629
        { "et", "lt", "lv" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   630
90ce3da70b43 Initial load
duke
parents:
diff changeset
   631
        /* ms874/Thai */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   632
        { "th" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   633
90ce3da70b43 Initial load
duke
parents:
diff changeset
   634
         /* ms932/Japanese */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   635
        { "ja" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   636
90ce3da70b43 Initial load
duke
parents:
diff changeset
   637
        /* gbk/Chinese (PRC GBK Cp950) */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   638
        { "zh", "zh_CN", },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   639
90ce3da70b43 Initial load
duke
parents:
diff changeset
   640
        /* ms949/Korean Extended Wansung */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   641
        { "ko" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   642
90ce3da70b43 Initial load
duke
parents:
diff changeset
   643
        /* ms950/Chinese (Taiwan, Hongkong, Macau) */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   644
        { "zh_HK", "zh_TW", },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   645
90ce3da70b43 Initial load
duke
parents:
diff changeset
   646
        /* ms1361/Korean Johab */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   647
        { "ko" },
90ce3da70b43 Initial load
duke
parents:
diff changeset
   648
    };
90ce3da70b43 Initial load
duke
parents:
diff changeset
   649
90ce3da70b43 Initial load
duke
parents:
diff changeset
   650
    private static final String codePages[] = {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   651
        "cp1252",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   652
        "cp1250",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   653
        "cp1251",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   654
        "cp1253",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   655
        "cp1254",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   656
        "cp1255",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   657
        "cp1256",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   658
        "cp1257",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   659
        "ms874",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   660
        "ms932",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   661
        "gbk",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   662
        "ms949",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   663
        "ms950",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   664
        "ms1361",
90ce3da70b43 Initial load
duke
parents:
diff changeset
   665
    };
90ce3da70b43 Initial load
duke
parents:
diff changeset
   666
90ce3da70b43 Initial load
duke
parents:
diff changeset
   667
    private static String defaultCodePage = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   668
    static String getCodePage() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   669
90ce3da70b43 Initial load
duke
parents:
diff changeset
   670
        if (defaultCodePage != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   671
            return defaultCodePage;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   672
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   673
90ce3da70b43 Initial load
duke
parents:
diff changeset
   674
        if (FontManager.isWindows) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   675
            defaultCodePage =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   676
                (String)java.security.AccessController.doPrivileged(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   677
                   new sun.security.action.GetPropertyAction("file.encoding"));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   678
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   679
            if (languages.length != codePages.length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   680
                throw new InternalError("wrong code pages array length");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   681
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   682
            Locale locale = sun.awt.SunToolkit.getStartupLocale();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   683
90ce3da70b43 Initial load
duke
parents:
diff changeset
   684
            String language = locale.getLanguage();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   685
            if (language != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   686
                if (language.equals("zh")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   687
                    String country = locale.getCountry();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   688
                    if (country != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   689
                        language = language + "_" + country;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   690
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   691
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   692
                for (int i=0; i<languages.length;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   693
                    for (int l=0;l<languages[i].length; l++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   694
                        if (language.equals(languages[i][l])) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   695
                            defaultCodePage = codePages[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   696
                            return defaultCodePage;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   697
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   698
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   699
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   700
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   701
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   702
        if (defaultCodePage == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   703
            defaultCodePage = "";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   704
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   705
        return defaultCodePage;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   706
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   707
90ce3da70b43 Initial load
duke
parents:
diff changeset
   708
    /* Theoretically, reserved bits must not be set, include symbol bits */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   709
    public static final int reserved_bits1 = 0x80000000;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   710
    public static final int reserved_bits2 = 0x0000ffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   711
    boolean supportsEncoding(String encoding) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   712
        if (encoding == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   713
            encoding = getCodePage();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   714
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   715
        if ("".equals(encoding)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   716
            return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   717
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   718
90ce3da70b43 Initial load
duke
parents:
diff changeset
   719
        encoding = encoding.toLowerCase();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   720
90ce3da70b43 Initial load
duke
parents:
diff changeset
   721
        /* java_props_md.c has a couple of special cases
90ce3da70b43 Initial load
duke
parents:
diff changeset
   722
         * if language packs are installed. In these encodings the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   723
         * fontconfig files pick up different fonts :
90ce3da70b43 Initial load
duke
parents:
diff changeset
   724
         * SimSun-18030 and MingLiU_HKSCS. Since these fonts will
90ce3da70b43 Initial load
duke
parents:
diff changeset
   725
         * indicate they support the base encoding, we need to rewrite
90ce3da70b43 Initial load
duke
parents:
diff changeset
   726
         * these encodings here before checking the map/array.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   727
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   728
        if (encoding.equals("gb18030")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   729
            encoding = "gbk";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   730
        } else if (encoding.equals("ms950_hkscs")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   731
            encoding = "ms950";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   732
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   733
90ce3da70b43 Initial load
duke
parents:
diff changeset
   734
        ByteBuffer buffer = getTableBuffer(os_2Tag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   735
        /* required info is at offsets 78 and 82 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   736
        if (buffer == null || buffer.capacity() < 86) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   737
            return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   738
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   739
90ce3da70b43 Initial load
duke
parents:
diff changeset
   740
        int range1 = buffer.getInt(78); /* ulCodePageRange1 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   741
        int range2 = buffer.getInt(82); /* ulCodePageRange2 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   742
90ce3da70b43 Initial load
duke
parents:
diff changeset
   743
        /* This test is too stringent for Arial on Solaris (and perhaps
90ce3da70b43 Initial load
duke
parents:
diff changeset
   744
         * other fonts). Arial has at least one reserved bit set for an
90ce3da70b43 Initial load
duke
parents:
diff changeset
   745
         * unknown reason.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   746
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   747
//         if (((range1 & reserved_bits1) | (range2 & reserved_bits2)) != 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   748
//             return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   749
//         }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   750
90ce3da70b43 Initial load
duke
parents:
diff changeset
   751
        for (int em=0; em<encoding_mapping.length; em++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   752
            if (encoding_mapping[em].equals(encoding)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   753
                if (((1 << em) & range1) != 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   754
                    return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   755
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   756
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   757
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   758
        return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   759
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   760
90ce3da70b43 Initial load
duke
parents:
diff changeset
   761
90ce3da70b43 Initial load
duke
parents:
diff changeset
   762
    /* Use info in the os_2Table to test CJK support */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   763
    private void setCJKSupport(ByteBuffer os2Table) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   764
        /* required info is in ulong at offset 46 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   765
        if (os2Table == null || os2Table.capacity() < 50) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   766
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   767
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   768
        int range2 = os2Table.getInt(46); /* ulUnicodeRange2 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   769
90ce3da70b43 Initial load
duke
parents:
diff changeset
   770
        /* Any of these bits set in the 32-63 range indicate a font with
90ce3da70b43 Initial load
duke
parents:
diff changeset
   771
         * support for a CJK range. We aren't looking at some other bits
90ce3da70b43 Initial load
duke
parents:
diff changeset
   772
         * in the 64-69 range such as half width forms as its unlikely a font
90ce3da70b43 Initial load
duke
parents:
diff changeset
   773
         * would include those and none of these.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   774
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   775
        supportsCJK = ((range2 & 0x29bf0000) != 0);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   776
90ce3da70b43 Initial load
duke
parents:
diff changeset
   777
        /* This should be generalised, but for now just need to know if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   778
         * Hiragana or Katakana ranges are supported by the font.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   779
         * In the 4 longs representing unicode ranges supported
90ce3da70b43 Initial load
duke
parents:
diff changeset
   780
         * bits 49 & 50 indicate hiragana and katakana
90ce3da70b43 Initial load
duke
parents:
diff changeset
   781
         * This is bits 17 & 18 in the 2nd ulong. If either is supported
90ce3da70b43 Initial load
duke
parents:
diff changeset
   782
         * we presume this is a JA font.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   783
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   784
        supportsJA = ((range2 & 0x60000) != 0);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   785
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   786
90ce3da70b43 Initial load
duke
parents:
diff changeset
   787
    boolean supportsJA() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   788
        return supportsJA;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   789
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   790
90ce3da70b43 Initial load
duke
parents:
diff changeset
   791
     ByteBuffer getTableBuffer(int tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   792
        DirectoryEntry entry = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   793
90ce3da70b43 Initial load
duke
parents:
diff changeset
   794
        for (int i=0;i<numTables;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   795
            if (tableDirectory[i].tag == tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   796
                entry = tableDirectory[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   797
                break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   798
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   799
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   800
        if (entry == null || entry.length == 0 ||
90ce3da70b43 Initial load
duke
parents:
diff changeset
   801
            entry.offset+entry.length > fileSize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   802
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   803
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   804
90ce3da70b43 Initial load
duke
parents:
diff changeset
   805
        int bread = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   806
        ByteBuffer buffer = ByteBuffer.allocate(entry.length);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   807
        synchronized (this) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   808
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   809
                if (disposerRecord.channel == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   810
                    open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   811
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   812
                disposerRecord.channel.position(entry.offset);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   813
                bread = disposerRecord.channel.read(buffer);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   814
                buffer.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   815
            } catch (ClosedChannelException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   816
                /* NIO I/O is interruptible, recurse to retry operation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   817
                 * Clear interrupts before recursing in case NIO didn't.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   818
                 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   819
                Thread.interrupted();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   820
                close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   821
                return getTableBuffer(tag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   822
            } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   823
                return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   824
            } catch (FontFormatException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   825
                return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   826
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   827
90ce3da70b43 Initial load
duke
parents:
diff changeset
   828
            if (bread < entry.length) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   829
                return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   830
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   831
                return buffer;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   832
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   833
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   834
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   835
90ce3da70b43 Initial load
duke
parents:
diff changeset
   836
    /* NB: is it better to move declaration to Font2D? */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   837
    long getLayoutTableCache() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   838
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   839
          return getScaler().getLayoutTableCache();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   840
        } catch(FontScalerException fe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   841
            return 0L;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   842
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   843
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   844
90ce3da70b43 Initial load
duke
parents:
diff changeset
   845
    byte[] getTableBytes(int tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   846
        ByteBuffer buffer = getTableBuffer(tag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   847
        if (buffer == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   848
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   849
        } else if (buffer.hasArray()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   850
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   851
                return buffer.array();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   852
            } catch (Exception re) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   853
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   854
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   855
        byte []data = new byte[getTableSize(tag)];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   856
        buffer.get(data);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   857
        return data;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   858
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   859
90ce3da70b43 Initial load
duke
parents:
diff changeset
   860
    int getTableSize(int tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   861
        for (int i=0;i<numTables;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   862
            if (tableDirectory[i].tag == tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   863
                return tableDirectory[i].length;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   864
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   865
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   866
        return 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   867
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   868
90ce3da70b43 Initial load
duke
parents:
diff changeset
   869
    int getTableOffset(int tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   870
        for (int i=0;i<numTables;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   871
            if (tableDirectory[i].tag == tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   872
                return tableDirectory[i].offset;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   873
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   874
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   875
        return 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   876
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   877
90ce3da70b43 Initial load
duke
parents:
diff changeset
   878
    DirectoryEntry getDirectoryEntry(int tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   879
        for (int i=0;i<numTables;i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   880
            if (tableDirectory[i].tag == tag) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   881
                return tableDirectory[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
   882
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   883
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   884
        return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   885
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   886
550
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   887
    /* Used to determine if this size has embedded bitmaps, which
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   888
     * for CJK fonts should be used in preference to LCD glyphs.
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   889
     */
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   890
    boolean useEmbeddedBitmapsForSize(int ptSize) {
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   891
        if (!supportsCJK) {
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   892
            return false;
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   893
        }
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   894
        if (getDirectoryEntry(EBLCTag) == null) {
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   895
            return false;
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   896
        }
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   897
        ByteBuffer eblcTable = getTableBuffer(EBLCTag);
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   898
        int numSizes = eblcTable.getInt(4);
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   899
        /* The bitmapSizeTable's start at offset of 8.
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   900
         * Each bitmapSizeTable entry is 48 bytes.
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   901
         * The offset of ppemY in the entry is 45.
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   902
         */
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   903
        for (int i=0;i<numSizes;i++) {
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   904
            int ppemY = eblcTable.get(8+(i*48)+45) &0xff;
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   905
            if (ppemY == ptSize) {
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   906
                return true;
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   907
            }
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   908
        }
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   909
        return false;
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   910
    }
e85f91b9bb95 6656651: Windows Look and Feel LCD glyph images have some differences from native applications.
prr
parents: 2
diff changeset
   911
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   912
    public String getFullName() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   913
        return fullName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   914
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   915
90ce3da70b43 Initial load
duke
parents:
diff changeset
   916
    /* This probably won't get called but is there to support the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   917
     * contract() of setStyle() defined in the superclass.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   918
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   919
    protected void setStyle() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   920
        setStyle(getTableBuffer(os_2Tag));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   921
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   922
90ce3da70b43 Initial load
duke
parents:
diff changeset
   923
    /* TrueTypeFont can use the fsSelection fields of OS/2 table
90ce3da70b43 Initial load
duke
parents:
diff changeset
   924
     * to determine the style. In the unlikely case that doesn't exist,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   925
     * can use macStyle in the 'head' table but simpler to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   926
     * fall back to super class algorithm of looking for well known string.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   927
     * A very few fonts don't specify this information, but I only
90ce3da70b43 Initial load
duke
parents:
diff changeset
   928
     * came across one: Lucida Sans Thai Typewriter Oblique in
90ce3da70b43 Initial load
duke
parents:
diff changeset
   929
     * /usr/openwin/lib/locale/th_TH/X11/fonts/TrueType/lucidai.ttf
90ce3da70b43 Initial load
duke
parents:
diff changeset
   930
     * that explicitly specified the wrong value. It says its regular.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   931
     * I didn't find any fonts that were inconsistent (ie regular plus some
90ce3da70b43 Initial load
duke
parents:
diff changeset
   932
     * other value).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   933
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   934
    private static final int fsSelectionItalicBit  = 0x00001;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   935
    private static final int fsSelectionBoldBit    = 0x00020;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   936
    private static final int fsSelectionRegularBit = 0x00040;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   937
    private void setStyle(ByteBuffer os_2Table) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   938
        /* fsSelection is unsigned short at buffer offset 62 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   939
        if (os_2Table == null || os_2Table.capacity() < 64) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   940
            super.setStyle();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   941
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   942
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   943
        int fsSelection = os_2Table.getChar(62) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   944
        int italic  = fsSelection & fsSelectionItalicBit;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   945
        int bold    = fsSelection & fsSelectionBoldBit;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   946
        int regular = fsSelection & fsSelectionRegularBit;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   947
//      System.out.println("platname="+platName+" font="+fullName+
90ce3da70b43 Initial load
duke
parents:
diff changeset
   948
//                         " family="+familyName+
90ce3da70b43 Initial load
duke
parents:
diff changeset
   949
//                         " R="+regular+" I="+italic+" B="+bold);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   950
        if (regular!=0 && ((italic|bold)!=0)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   951
            /* This is inconsistent. Try using the font name algorithm */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   952
            super.setStyle();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   953
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   954
        } else if ((regular|italic|bold) == 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   955
            /* No style specified. Try using the font name algorithm */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   956
            super.setStyle();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   957
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   958
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   959
        switch (bold|italic) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   960
        case fsSelectionItalicBit:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   961
            style = Font.ITALIC;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   962
            break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   963
        case fsSelectionBoldBit:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   964
            if (FontManager.isSolaris && platName.endsWith("HG-GothicB.ttf")) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   965
                /* Workaround for Solaris's use of a JA font that's marked as
90ce3da70b43 Initial load
duke
parents:
diff changeset
   966
                 * being designed bold, but is used as a PLAIN font.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   967
                 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   968
                style = Font.PLAIN;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   969
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   970
                style = Font.BOLD;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   971
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   972
            break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   973
        case fsSelectionBoldBit|fsSelectionItalicBit:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   974
            style = Font.BOLD|Font.ITALIC;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   975
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   976
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   977
90ce3da70b43 Initial load
duke
parents:
diff changeset
   978
    private float stSize, stPos, ulSize, ulPos;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   979
90ce3da70b43 Initial load
duke
parents:
diff changeset
   980
    private void setStrikethroughMetrics(ByteBuffer os_2Table, int upem) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   981
        if (os_2Table == null || os_2Table.capacity() < 30 || upem < 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   982
            stSize = .05f;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   983
            stPos = -.4f;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   984
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   985
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   986
        ShortBuffer sb = os_2Table.asShortBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   987
        stSize = sb.get(13) / (float)upem;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   988
        stPos = -sb.get(14) / (float)upem;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   989
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   990
90ce3da70b43 Initial load
duke
parents:
diff changeset
   991
    private void setUnderlineMetrics(ByteBuffer postTable, int upem) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   992
        if (postTable == null || postTable.capacity() < 12 || upem < 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   993
            ulSize = .05f;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   994
            ulPos = .1f;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   995
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   996
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   997
        ShortBuffer sb = postTable.asShortBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   998
        ulSize = sb.get(5) / (float)upem;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   999
        ulPos = -sb.get(4) / (float)upem;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1000
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1001
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1002
    public void getStyleMetrics(float pointSize, float[] metrics, int offset) {
2693
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1003
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1004
        if (ulSize == 0f && ulPos == 0f) {
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1005
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1006
            ByteBuffer head_Table = getTableBuffer(headTag);
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1007
            int upem = -1;
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1008
            if (head_Table != null && head_Table.capacity() >= 18) {
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1009
                ShortBuffer sb = head_Table.asShortBuffer();
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1010
                upem = sb.get(9) & 0xffff;
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1011
            }
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1012
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1013
            ByteBuffer os2_Table = getTableBuffer(os_2Tag);
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1014
            setStrikethroughMetrics(os2_Table, upem);
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1015
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1016
            ByteBuffer post_Table = getTableBuffer(postTag);
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1017
            setUnderlineMetrics(post_Table, upem);
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1018
        }
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1019
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1020
        metrics[offset] = stPos * pointSize;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1021
        metrics[offset+1] = stSize * pointSize;
2693
f87942d1edba 6753173: No need to read all the TrueType 'post' table to get underline info
prr
parents: 1721
diff changeset
  1022
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1023
        metrics[offset+2] = ulPos * pointSize;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1024
        metrics[offset+3] = ulSize * pointSize;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1025
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1026
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1027
    private String makeString(byte[] bytes, int len, short encoding) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1028
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1029
        /* Check for fonts using encodings 2->6 is just for
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1030
         * some old DBCS fonts, apparently mostly on Solaris.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1031
         * Some of these fonts encode ascii names as double-byte characters.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1032
         * ie with a leading zero byte for what properly should be a
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1033
         * single byte-char.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1034
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1035
        if (encoding >=2 && encoding <= 6) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1036
             byte[] oldbytes = bytes;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1037
             int oldlen = len;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1038
             bytes = new byte[oldlen];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1039
             len = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1040
             for (int i=0; i<oldlen; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1041
                 if (oldbytes[i] != 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1042
                     bytes[len++] = oldbytes[i];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1043
                 }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1044
             }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1045
         }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1046
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1047
        String charset;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1048
        switch (encoding) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1049
            case 1:  charset = "UTF-16";  break; // most common case first.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1050
            case 0:  charset = "UTF-16";  break; // symbol uses this
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1051
            case 2:  charset = "SJIS";    break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1052
            case 3:  charset = "GBK";     break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1053
            case 4:  charset = "MS950";   break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1054
            case 5:  charset = "EUC_KR";  break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1055
            case 6:  charset = "Johab";   break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1056
            default: charset = "UTF-16";  break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1057
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1058
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1059
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1060
            return new String(bytes, 0, len, charset);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1061
        } catch (UnsupportedEncodingException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1062
            if (FontManager.logging) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1063
                FontManager.logger.warning(e + " EncodingID=" + encoding);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1064
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1065
            return new String(bytes, 0, len);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1066
        } catch (Throwable t) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1067
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1068
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1069
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1070
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1071
    protected void initNames() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1072
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1073
        byte[] name = new byte[256];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1074
        ByteBuffer buffer = getTableBuffer(nameTag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1075
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1076
        if (buffer != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1077
            ShortBuffer sbuffer = buffer.asShortBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1078
            sbuffer.get(); // format - not needed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1079
            short numRecords = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1080
            /* The name table uses unsigned shorts. Many of these
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1081
             * are known small values that fit in a short.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1082
             * The values that are sizes or offsets into the table could be
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1083
             * greater than 32767, so read and store those as ints
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1084
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1085
            int stringPtr = sbuffer.get() & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1086
            for (int i=0; i<numRecords; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1087
                short platformID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1088
                if (platformID != MS_PLATFORM_ID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1089
                    sbuffer.position(sbuffer.position()+5);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1090
                    continue; // skip over this record.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1091
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1092
                short encodingID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1093
                short langID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1094
                short nameID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1095
                int nameLen    = ((int) sbuffer.get()) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1096
                int namePtr    = (((int) sbuffer.get()) & 0xffff) + stringPtr;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1097
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1098
                switch (nameID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1099
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1100
                case FAMILY_NAME_ID:
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1101
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1102
                    if (familyName == null || langID == ENGLISH_LOCALE_ID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1103
                        buffer.position(namePtr);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1104
                        buffer.get(name, 0, nameLen);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1105
                        familyName = makeString(name, nameLen, encodingID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1106
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1107
/*
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1108
                    for (int ii=0;ii<nameLen;ii++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1109
                        int val = (int)name[ii]&0xff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1110
                        System.err.print(Integer.toHexString(val)+ " ");
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1111
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1112
                    System.err.println();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1113
                    System.err.println("familyName="+familyName +
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1114
                                       " nameLen="+nameLen+
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1115
                                       " langID="+langID+ " eid="+encodingID +
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1116
                                       " str len="+familyName.length());
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1117
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1118
*/
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1119
                    break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1120
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1121
                case FULL_NAME_ID:
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1122
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1123
                    if (fullName == null || langID == ENGLISH_LOCALE_ID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1124
                        buffer.position(namePtr);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1125
                        buffer.get(name, 0, nameLen);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1126
                        fullName = makeString(name, nameLen, encodingID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1127
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1128
                    break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1129
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1130
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1131
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1132
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1133
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1134
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1135
    /* Return the requested name in the requested locale, for the
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1136
     * MS platform ID. If the requested locale isn't found, return US
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1137
     * English, if that isn't found, return null and let the caller
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1138
     * figure out how to handle that.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1139
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1140
    protected String lookupName(short findLocaleID, int findNameID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1141
        String foundName = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1142
        byte[] name = new byte[1024];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1143
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1144
        ByteBuffer buffer = getTableBuffer(nameTag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1145
        if (buffer != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1146
            ShortBuffer sbuffer = buffer.asShortBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1147
            sbuffer.get(); // format - not needed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1148
            short numRecords = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1149
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1150
            /* The name table uses unsigned shorts. Many of these
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1151
             * are known small values that fit in a short.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1152
             * The values that are sizes or offsets into the table could be
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1153
             * greater than 32767, so read and store those as ints
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1154
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1155
            int stringPtr = ((int) sbuffer.get()) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1156
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1157
            for (int i=0; i<numRecords; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1158
                short platformID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1159
                if (platformID != MS_PLATFORM_ID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1160
                    sbuffer.position(sbuffer.position()+5);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1161
                    continue; // skip over this record.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1162
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1163
                short encodingID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1164
                short langID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1165
                short nameID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1166
                int   nameLen    = ((int) sbuffer.get()) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1167
                int   namePtr    = (((int) sbuffer.get()) & 0xffff) + stringPtr;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1168
                if (nameID == findNameID &&
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1169
                    ((foundName == null && langID == ENGLISH_LOCALE_ID)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1170
                     || langID == findLocaleID)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1171
                    buffer.position(namePtr);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1172
                    buffer.get(name, 0, nameLen);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1173
                    foundName = makeString(name, nameLen, encodingID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1174
                    if (langID == findLocaleID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1175
                        return foundName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1176
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1177
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1178
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1179
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1180
        return foundName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1181
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1182
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1183
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1184
     * @return number of logical fonts. Is "1" for all but TTC files
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1185
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1186
    public int getFontCount() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1187
        return directoryCount;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1188
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1189
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1190
    protected synchronized FontScaler getScaler() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1191
        if (scaler == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1192
            scaler = FontManager.getScaler(this, fontIndex,
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1193
                supportsCJK, fileSize);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1194
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1195
        return scaler;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1196
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1197
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1198
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1199
    /* Postscript name is rarely requested. Don't waste cycles locating it
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1200
     * as part of font creation, nor storage to hold it. Get it only on demand.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1201
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1202
    public String getPostscriptName() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1203
        String name = lookupName(ENGLISH_LOCALE_ID, POSTSCRIPT_NAME_ID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1204
        if (name == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1205
            return fullName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1206
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1207
            return name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1208
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1209
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1210
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1211
    public String getFontName(Locale locale) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1212
        if (locale == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1213
            return fullName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1214
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1215
            short localeID = FontManager.getLCIDFromLocale(locale);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1216
            String name = lookupName(localeID, FULL_NAME_ID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1217
            if (name == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1218
                return fullName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1219
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1220
                return name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1221
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1222
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1223
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1224
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1225
    public String getFamilyName(Locale locale) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1226
        if (locale == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1227
            return familyName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1228
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1229
            short localeID = FontManager.getLCIDFromLocale(locale);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1230
            String name = lookupName(localeID, FAMILY_NAME_ID);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1231
            if (name == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1232
                return familyName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1233
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1234
                return name;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1235
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1236
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1237
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1238
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1239
    public CharToGlyphMapper getMapper() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1240
        if (mapper == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1241
            mapper = new TrueTypeGlyphMapper(this);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1242
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1243
        return mapper;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1244
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1245
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1246
    /* This duplicates initNames() but that has to run fast as its used
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1247
     * during typical start-up and the information here is likely never
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1248
     * needed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1249
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1250
    protected void initAllNames(int requestedID, HashSet names) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1251
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1252
        byte[] name = new byte[256];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1253
        ByteBuffer buffer = getTableBuffer(nameTag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1254
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1255
        if (buffer != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1256
            ShortBuffer sbuffer = buffer.asShortBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1257
            sbuffer.get(); // format - not needed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1258
            short numRecords = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1259
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1260
            /* The name table uses unsigned shorts. Many of these
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1261
             * are known small values that fit in a short.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1262
             * The values that are sizes or offsets into the table could be
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1263
             * greater than 32767, so read and store those as ints
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1264
             */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1265
            int stringPtr = ((int) sbuffer.get()) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1266
            for (int i=0; i<numRecords; i++) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1267
                short platformID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1268
                if (platformID != MS_PLATFORM_ID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1269
                    sbuffer.position(sbuffer.position()+5);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1270
                    continue; // skip over this record.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1271
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1272
                short encodingID = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1273
                short langID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1274
                short nameID     = sbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1275
                int   nameLen    = ((int) sbuffer.get()) & 0xffff;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1276
                int   namePtr    = (((int) sbuffer.get()) & 0xffff) + stringPtr;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1277
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1278
                if (nameID == requestedID) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1279
                    buffer.position(namePtr);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1280
                    buffer.get(name, 0, nameLen);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1281
                    names.add(makeString(name, nameLen, encodingID));
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1282
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1283
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1284
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1285
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1286
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1287
    String[] getAllFamilyNames() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1288
        HashSet aSet = new HashSet();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1289
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1290
            initAllNames(FAMILY_NAME_ID, aSet);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1291
        } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1292
            /* In case of malformed font */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1293
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1294
        return (String[])aSet.toArray(new String[0]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1295
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1296
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1297
    String[] getAllFullNames() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1298
        HashSet aSet = new HashSet();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1299
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1300
            initAllNames(FULL_NAME_ID, aSet);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1301
        } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1302
            /* In case of malformed font */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1303
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1304
        return (String[])aSet.toArray(new String[0]);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1305
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1306
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1307
    /*  Used by the OpenType engine for mark positioning.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1308
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1309
    Point2D.Float getGlyphPoint(long pScalerContext,
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1310
                                int glyphCode, int ptNumber) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1311
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1312
            return getScaler().getGlyphPoint(pScalerContext,
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1313
                                             glyphCode, ptNumber);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1314
        } catch(FontScalerException fe) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1315
            return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1316
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1317
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1318
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1319
    private char[] gaspTable;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1320
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1321
    private char[] getGaspTable() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1322
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1323
        if (gaspTable != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1324
            return gaspTable;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1325
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1326
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1327
        ByteBuffer buffer = getTableBuffer(gaspTag);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1328
        if (buffer == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1329
            return gaspTable = new char[0];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1330
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1331
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1332
        CharBuffer cbuffer = buffer.asCharBuffer();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1333
        char format = cbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1334
        /* format "1" has appeared for some Windows Vista fonts.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1335
         * Its presently undocumented but the existing values
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1336
         * seem to be still valid so we can use it.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1337
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1338
        if (format > 1) { // unrecognised format
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1339
            return gaspTable = new char[0];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1340
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1341
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1342
        char numRanges = cbuffer.get();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1343
        if (4+numRanges*4 > getTableSize(gaspTag)) { // sanity check
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1344
            return gaspTable = new char[0];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1345
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1346
        gaspTable = new char[2*numRanges];
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1347
        cbuffer.get(gaspTable);
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1348
        return gaspTable;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1349
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1350
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1351
    /* This is to obtain info from the TT 'gasp' (grid-fitting and
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1352
     * scan-conversion procedure) table which specifies three combinations:
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1353
     * Hint, Smooth (greyscale), Hint and Smooth.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1354
     * In this simplified scheme we don't distinguish the latter two. We
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1355
     * hint even at small sizes, so as to preserve metrics consistency.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1356
     * If the information isn't available default values are substituted.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1357
     * The more precise defaults we'd do if we distinguished the cases are:
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1358
     * Bold (no other style) fonts :
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1359
     * 0-8 : Smooth ( do grey)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1360
     * 9+  : Hint + smooth (gridfit + grey)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1361
     * Plain, Italic and Bold-Italic fonts :
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1362
     * 0-8 : Smooth ( do grey)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1363
     * 9-17 : Hint (gridfit)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1364
     * 18+  : Hint + smooth (gridfit + grey)
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1365
     * The defaults should rarely come into play as most TT fonts provide
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1366
     * better defaults.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1367
     * REMIND: consider unpacking the table into an array of booleans
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1368
     * for faster use.
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1369
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1370
    public boolean useAAForPtSize(int ptsize) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1371
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1372
        char[] gasp = getGaspTable();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1373
        if (gasp.length > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1374
            for (int i=0;i<gasp.length;i+=2) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1375
                if (ptsize <= gasp[i]) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1376
                    return ((gasp[i+1] & 0x2) != 0); // bit 2 means DO_GRAY;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1377
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1378
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1379
            return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1380
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1381
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1382
        if (style == Font.BOLD) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1383
            return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1384
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1385
            return ptsize <= 8 || ptsize >= 18;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1386
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1387
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1388
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1389
    public boolean hasSupplementaryChars() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1390
        return ((TrueTypeGlyphMapper)getMapper()).hasSupplementaryChars();
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1391
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1392
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1393
    public String toString() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1394
        return "** TrueType Font: Family="+familyName+ " Name="+fullName+
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1395
            " style="+style+" fileName="+platName;
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1396
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1397
}