annotate org/eclipse/swt/graphics/FontData.d @ 5:de77855733ca

more ...
author Frank Benoit <benoit@tionex.de>
date Sat, 05 Jan 2008 05:40:52 +0100
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
1 /*******************************************************************************
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
2 * Copyright (c) 2000, 2007 IBM Corporation and others.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
10 *******************************************************************************/
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
11 module org.eclipse.swt.graphics.FontData;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
12
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
13
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14 import org.eclipse.swt.SWT;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
15
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16 import tango.text.convert.Format;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
17 import tango.text.Util : locate;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 import tango.util.Convert;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
21 * Instances of this class describe operating system fonts.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 * For platform-independent behaviour, use the get and set methods
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24 * corresponding to the following properties:
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
25 * <dl>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
26 * <dt>height</dt><dd>the height of the font in points</dd>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
27 * <dt>name</dt><dd>the face name of the font, which may include the foundry</dd>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
28 * <dt>style</dt><dd>A bitwise combination of NORMAL, ITALIC and BOLD</dd>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
29 * </dl>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
30 * If extra, platform-dependent functionality is required:
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
31 * <ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32 * <li>On <em>Windows</em>, the data member of the <code>FontData</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 * corresponds to a Windows <code>LOGFONT</code> structure whose fields
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34 * may be retrieved and modified.</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 * <li>On <em>X</em>, the fields of the <code>FontData</code> correspond
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 * to the entries in the font's XLFD name and may be retrieved and modified.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 * </ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 * Application code does <em>not</em> need to explicitly release the
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 * resources managed by each instance when those instances are no longer
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 * required, and thus no <code>dispose()</code> method is provided.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 * @see Font
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44 public final class FontData {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 * the font name
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 * (Warning: This field is platform dependent)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 * <b>IMPORTANT:</b> This field is <em>not</em> part of the SWT
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 * public API. It is marked public only so that it can be shared
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
51 * within the packages provided by SWT. It is not available on all
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 * platforms and should never be accessed from application code.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55 public char[] name;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
57 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58 * The height of the font data in points
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 * (Warning: This field is platform dependent)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 * <b>IMPORTANT:</b> This field is <em>not</em> part of the SWT
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62 * public API. It is marked public only so that it can be shared
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63 * within the packages provided by SWT. It is not available on all
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 * platforms and should never be accessed from application code.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 public float height;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70 * the font style
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 * (Warning: This field is platform dependent)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 * <b>IMPORTANT:</b> This field is <em>not</em> part of the SWT
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74 * public API. It is marked public only so that it can be shared
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 * within the packages provided by SWT. It is not available on all
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76 * platforms and should never be accessed from application code.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
78 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
79 public int style;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
80
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
81 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
82 * the Pango string
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
83 * (Warning: This field is platform dependent)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
84 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
85 * <b>IMPORTANT:</b> This field is <em>not</em> part of the SWT
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
86 * public API. It is marked public only so that it can be shared
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
87 * within the packages provided by SWT. It is not available on all
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
88 * platforms and should never be accessed from application code.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
89 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
90 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
91 public byte[] str;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
92
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
93 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
94 * The locales of the font
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
95 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
96 char[] lang, country, variant;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
97
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
98 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
99 * Constructs a new uninitialized font data.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
100 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
101 public this () {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
102 this("", 12, SWT.NORMAL);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
103 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
104
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
105 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
106 * Constructs a new FontData given a string representation
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
107 * in the form generated by the <code>FontData.toString</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
108 * method.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
109 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
110 * Note that the representation varies between platforms,
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
111 * and a FontData can only be created from a string that was
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
112 * generated on the same platform.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
113 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
114 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
115 * @param string the string representation of a <code>FontData</code> (must not be null)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
116 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
117 * @exception IllegalArgumentException <ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
118 * <li>ERROR_NULL_ARGUMENT - if the argument is null</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
119 * <li>ERROR_INVALID_ARGUMENT - if the argument does not represent a valid description</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
120 * </ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
121 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
122 * @see #toString
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
123 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
124 public this(char[] str) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
125 if (str is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
126 int start = 0;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
127 int end = locate( str, '|' );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
128 if (end == str.length ) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
129 char[] version1 = str[ start .. end ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
130 try {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
131 if (to!(int)(version1) != 1) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
132 } catch (ConversionException e) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
133 SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
134 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
135
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
136 start = end + 1;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
137 end = locate( str, '|', start );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
138 if (end == str.length ) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
139 char[] name = str[start .. end ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
140
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
141 start = end + 1;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
142 end = locate( str, '|', start );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
143 if (end == str.length ) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
144 float height = 0;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
145 try {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
146 height = to!(float)(str[start .. end]);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
147 } catch (ConversionException e) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
148 SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
149 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
150
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
151 start = end + 1;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
152 end = locate( str, '|', start );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
153 if (end == str.length ) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
154 int style = 0;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
155 try {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
156 style = to!(int)( str[start .. end ]);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
157 } catch (ConversionException e) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
158 SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
159 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
160
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
161 start = end + 1;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
162 end = locate( str, '|', start );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
163 setName(name);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
164 setHeight(height);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
165 setStyle(style);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
166 if (end == str.length) return;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
167 char[] platform = str[ start .. end ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
168
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
169 start = end + 1;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
170 end = locate( str, '|', start );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
171 if (end == str.length) return;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
172 char[] version2 = str[ start .. end ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
173
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
174 if (platform == "GTK" && version2 == "1" ) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
175 return;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
176 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
177 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
178
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
179 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
180 * Constructs a new font data given a font name,
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
181 * the height of the desired font in points,
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
182 * and a font style.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
183 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
184 * @param name the name of the font (must not be null)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
185 * @param height the font height in points
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
186 * @param style a bit or combination of NORMAL, BOLD, ITALIC
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
187 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
188 * @exception IllegalArgumentException <ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
189 * <li>ERROR_NULL_ARGUMENT - when the font name is null</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
190 * <li>ERROR_INVALID_ARGUMENT - if the height is negative</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
191 * </ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
192 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
193 public this(char[] name, int height, int style) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
194 setName(name);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
195 setHeight(height);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
196 setStyle(style);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
197 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
198
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
199 /*public*/ this(char[] name, float height, int style) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
200 setName(name);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
201 setHeight(height);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
202 setStyle(style);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
203 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
204
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
205 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
206 * Compares the argument to the receiver, and returns true
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
207 * if they represent the <em>same</em> object using a class
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
208 * specific comparison.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
209 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
210 * @param object the object to compare with this object
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
211 * @return <code>true</code> if the object is the same as this object and <code>false</code> otherwise
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
212 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
213 * @see #hashCode
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
214 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
215 public override int opEquals (Object object) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
216 if (object is this) return true;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
217 if( auto data = cast(FontData)object ){
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
218 return name == data.name && height == data.height && style == data.style;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
219 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
220 return false;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
221 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
222
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
223 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
224 * Returns the height of the receiver in points.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
225 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
226 * @return the height of this FontData
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
227 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
228 * @see #setHeight(int)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
229 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
230 public int getHeight() {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
231 return cast(int)(0.5f + height);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
232 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
233
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
234 /*public*/ float getHeightF() {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
235 return height;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
236 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
237
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
238 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
239 * Returns the locale of the receiver.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
240 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
241 * The locale determines which platform character set this
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
242 * font is going to use. Widgets and graphics operations that
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
243 * use this font will convert UNICODE strings to the platform
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
244 * character set of the specified locale.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
245 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
246 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
247 * On platforms where there are multiple character sets for a
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
248 * given language/country locale, the variant portion of the
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
249 * locale will determine the character set.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
250 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
251 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
252 * @return the <code>String</code> representing a Locale object
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
253 * @since 3.0
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
254 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
255 public char[] getLocale () {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
256 char[] result;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
257 const char sep = '_';
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
258 if (lang != null) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
259 result ~= lang;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
260 result ~= sep;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
261 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
262 if (country != null) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
263 result ~= country;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
264 result ~= sep;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
265 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
266 if (variant != null) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
267 result ~= variant;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
268 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
269
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
270 if (result) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
271 if (result[$-1] == sep) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
272 result = result[0 .. $ - 1];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
273 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
274 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
275 return result;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
276 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
277
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
278 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
279 * Returns the name of the receiver.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
280 * On platforms that support font foundries, the return value will
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
281 * be the foundry followed by a dash ("-") followed by the face name.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
282 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
283 * @return the name of this <code>FontData</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
284 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
285 * @see #setName
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
286 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
287 public char[] getName() {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
288 return name;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
289 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
290
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
291 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
292 * Returns the style of the receiver which is a bitwise OR of
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
293 * one or more of the <code>SWT</code> constants NORMAL, BOLD
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
294 * and ITALIC.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
295 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
296 * @return the style of this <code>FontData</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
297 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
298 * @see #setStyle
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
299 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
300 public int getStyle() {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
301 return style;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
302 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
303
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
304 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
305 * Returns an integer hash code for the receiver. Any two
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
306 * objects that return <code>true</code> when passed to
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
307 * <code>equals</code> must return the same value for this
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
308 * method.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
309 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
310 * @return the receiver's hash
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
311 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
312 * @see #equals
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
313 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
314 public hash_t toHash () {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
315 return typeid(char[]).getHash(&name) ^ getHeight() ^ style;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
316 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
317
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
318 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
319 * Sets the height of the receiver. The parameter is
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
320 * specified in terms of points, where a point is one
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
321 * seventy-second of an inch.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
322 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
323 * @param height the height of the <code>FontData</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
324 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
325 * @exception IllegalArgumentException <ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
326 * <li>ERROR_INVALID_ARGUMENT - if the height is negative</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
327 * </ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
328 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
329 * @see #getHeight
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
330 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
331 public void setHeight(int height) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
332 if (height < 0) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
333 this.height = height;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
334 this.str = null;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
335 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
336
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
337 /*public*/ void setHeight(float height) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
338 if (height < 0) SWT.error(SWT.ERROR_INVALID_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
339 this.height = height;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
340 this.str = null;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
341 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
342
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
343 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
344 * Sets the locale of the receiver.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
345 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
346 * The locale determines which platform character set this
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
347 * font is going to use. Widgets and graphics operations that
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
348 * use this font will convert UNICODE strings to the platform
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
349 * character set of the specified locale.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
350 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
351 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
352 * On platforms where there are multiple character sets for a
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
353 * given language/country locale, the variant portion of the
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
354 * locale will determine the character set.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
355 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
356 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
357 * @param locale the <code>String</code> representing a Locale object
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
358 * @see java.util.Locale#toString
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
359 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
360 public void setLocale(char[] locale) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
361 lang = country = variant = null;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
362 if (locale !is null) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
363 char sep = '_';
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
364 int length = locale.length;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
365 int firstSep, secondSep;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
366
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
367 firstSep = locate( locale, sep );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
368 if (firstSep == locale.length) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
369 firstSep = secondSep = length;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
370 } else {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
371 secondSep = locate( locale, sep, firstSep + 1);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
372 if (secondSep == locale.length) secondSep = length;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
373 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
374 if (firstSep > 0) lang = locale[0 .. firstSep];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
375 if (secondSep > firstSep + 1) country = locale[firstSep + 1 .. secondSep ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
376 if (length > secondSep + 1) variant = locale[secondSep + 1 .. $ ];
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
377 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
378 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
379
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
380 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
381 * Sets the name of the receiver.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
382 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
383 * Some platforms support font foundries. On these platforms, the name
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
384 * of the font specified in setName() may have one of the following forms:
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
385 * <ol>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
386 * <li>a face name (for example, "courier")</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
387 * <li>a foundry followed by a dash ("-") followed by a face name (for example, "adobe-courier")</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
388 * </ol>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
389 * In either case, the name returned from getName() will include the
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
390 * foundry.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
391 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
392 * <p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
393 * On platforms that do not support font foundries, only the face name
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
394 * (for example, "courier") is used in <code>setName()</code> and
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
395 * <code>getName()</code>.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
396 * </p>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
397 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
398 * @param name the name of the font data (must not be null)
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
399 * @exception IllegalArgumentException <ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
400 * <li>ERROR_NULL_ARGUMENT - when the font name is null</li>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
401 * </ul>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
402 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
403 * @see #getName
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
404 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
405 public void setName(char[] name) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
406 if (name is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
407 this.name = name;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
408 this.str = null;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
409 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
410
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
411 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
412 * Sets the style of the receiver to the argument which must
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
413 * be a bitwise OR of one or more of the <code>SWT</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
414 * constants NORMAL, BOLD and ITALIC. All other style bits are
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
415 * ignored.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
416 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
417 * @param style the new style for this <code>FontData</code>
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
418 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
419 * @see #getStyle
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
420 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
421 public void setStyle(int style) {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
422 this.style = style;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
423 this.str = null;
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
424 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
425
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
426 /**
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
427 * Returns a string representation of the receiver which is suitable
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
428 * for constructing an equivalent instance using the
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
429 * <code>FontData(String)</code> constructor.
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
430 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
431 * @return a string representation of the FontData
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
432 *
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
433 * @see FontData
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
434 */
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
435 public char[] toString() {
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
436 return Format( "1|{}|{}|{}|GTK|1|", getName, getHeightF, getStyle );
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
437 }
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
438
de77855733ca more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
439 }