/******************************************************************************* * Copyright (c) 2004, 2006 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.jface.resource; import org.eclipse.rwt.graphics.Graphics; import org.eclipse.swt.graphics.Device; import org.eclipse.swt.graphics.Font; import org.eclipse.swt.graphics.FontData; /** * Describes a Font using an array of FontData * * @since 1.0 */ final class ArrayFontDescriptor extends FontDescriptor { private FontData[] data; private Font originalFont = null; // RAP [bm]: /** * Creates a font descriptor for a font with the given name, height, * and style. These arguments are passed directly to the constructor * of Font. * * @param data FontData describing the font to create * * <!--@see org.eclipse.swt.graphics.Font#Font(org.eclipse.swt.graphics.Device, org.eclipse.swt.graphics.FontData)--> * @see org.eclipse.rwt.graphics.Graphics#getFont(org.eclipse.swt.graphics.FontData) * * @since 1.0 */ public ArrayFontDescriptor(FontData[] data) { this.data = data; } /** * Creates a font descriptor that describes the given font. * * @param originalFont font to be described * * @see FontDescriptor#createFrom(org.eclipse.swt.graphics.Font) * @since 1.0 */ public ArrayFontDescriptor(Font originalFont) { this(originalFont.getFontData()); this.originalFont = originalFont; } /* (non-Javadoc) * @see org.eclipse.jface.resource.FontDescriptor#getFontData() */ public FontData[] getFontData() { // Copy the original array to ensure that callers will not modify it return copy(data); } /* (non-Javadoc) * @see org.eclipse.jface.resource.FontDescriptor#createFont(org.eclipse.swt.graphics.Device) */ public Font createFont(Device device) { // If this descriptor is an existing font, then we can return the original font // if this is the same device. if (originalFont != null) { // If we're allocating on the same device as the original font, return the original. // RAP [bm]: // if (originalFont.getDevice() == device) { // return originalFont; // } return originalFont; // RAPEND: [bm] } // RAP [bm]: // return new Font(device, data); return Graphics.getFont(data[0]); // RAPEND: [bm] } /* (non-Javadoc) * @see java.lang.Object#equals(java.lang.Object) */ public boolean equals(Object obj) { if ((obj.getClass() == ArrayFontDescriptor.class)) { ArrayFontDescriptor descr = (ArrayFontDescriptor)obj; if (descr.originalFont != originalFont) { return false; } if (originalFont != null) { return true; } if (data.length != descr.data.length) { return false; } for (int i = 0; i < data.length; i++) { FontData fd = data[i]; FontData fd2 = descr.data[i]; if (!fd.equals(fd2)) { return false; } } return true; } return false; } /* (non-Javadoc) * @see java.lang.Object#hashCode() */ public int hashCode() { if (originalFont != null) { return originalFont.hashCode(); } int code = 0; for (int i = 0; i < data.length; i++) { FontData fd = data[i]; code += fd.hashCode(); } return code; } /* (non-Javadoc) * @see org.eclipse.jface.resource.FontDescriptor#destroyFont(org.eclipse.swt.graphics.Font) */ public void destroyFont(Font previouslyCreatedFont) { if (previouslyCreatedFont == originalFont) { return; } // RAP [bm]: Font#dispose // previouslyCreatedFont.dispose(); } }