annotate dwt/graphics/FontData.d @ 259:c0d810de7093

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