annotate dwtx/jface/preference/PreferenceConverter.d @ 104:04b47443bb01

Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections. These new wrappers now use the tango.util.containers instead of the tango.util.collections.
author Frank Benoit <benoit@tionex.de>
date Thu, 07 Aug 2008 15:01:33 +0200
parents eb3ef3b7e244
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
1 /*******************************************************************************
90
7ffeace6c47f Update 3.4M7 to 3.4
Frank Benoit <benoit@tionex.de>
parents: 34
diff changeset
2 * Copyright (c) 2000, 2008 IBM Corporation and others.
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
10 * Port to the D programming language:
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
11 * Frank Benoit <benoit@tionex.de>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
12 *******************************************************************************/
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
13 module dwtx.jface.preference.PreferenceConverter;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
15 import dwtx.jface.preference.IPreferenceStore;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
17 // import java.util.Arrays;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 // import java.util.StringTokenizer;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 import dwt.DWTException;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
21 import dwt.graphics.FontData;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22 import dwt.graphics.Point;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 import dwt.graphics.RGB;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24 import dwt.graphics.Rectangle;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
25 import dwt.widgets.Display;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
26 import dwtx.jface.resource.JFaceResources;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
27 import dwtx.jface.resource.StringConverter;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
28
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
29 import dwt.dwthelper.utils;
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 93
diff changeset
30 import dwtx.dwtxhelper.Collection;
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
31
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 * A utility class for dealing with preferences whose values are
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34 * common DWT objects (color, points, rectangles, and font data).
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 * The static methods on this class handle the conversion between
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 * the DWT objects and their string representations.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 * <p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 * Usage:
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 * <pre>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 * IPreferenceStore store = ...;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 * PreferenceConverter.setValue(store, "bg", new RGB(127,127,127));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 * ...
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43 * RBG bgColor = PreferenceConverter.getValue(store, "bg");
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44 * </pre>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 * </p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 * <p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 * This class contains static methods and fields only and cannot
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 * be instantiated.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 * </p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 * Note: touching this class has the side effect of creating a display (static initializer).
90
7ffeace6c47f Update 3.4M7 to 3.4
Frank Benoit <benoit@tionex.de>
parents: 34
diff changeset
51 * @noinstantiate This class is not intended to be instantiated by clients.
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53 public class PreferenceConverter {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56 * The default-default value for point preferences
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
57 * (the origin, <code>(0,0)</code>).
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 public static const Point POINT_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62 * The default-default value for rectangle preferences
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63 * (the empty rectangle <code>(0,0,0,0)</code>).
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65 public static const Rectangle RECTANGLE_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68 * The default-default value for color preferences
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69 * (black, <code>RGB(0,0,0)</code>).
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 public static const RGB COLOR_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 private static const String ENTRY_SEPARATOR = ";"; //$NON-NLS-1$
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76 * The default-default value for <code>FontData[]</code> preferences.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 */
93
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
78 private static bool FONTDATA_ARRAY_DEFAULT_DEFAULT_initialized = false;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
79 private static FontData[] FONTDATA_ARRAY_DEFAULT_DEFAULT_;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
80 public static FontData[] FONTDATA_ARRAY_DEFAULT_DEFAULT(){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
81 if( !FONTDATA_ARRAY_DEFAULT_DEFAULT_initialized ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
82 synchronized( PreferenceConverter.classinfo ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
83 if( !FONTDATA_ARRAY_DEFAULT_DEFAULT_initialized ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
84 Display display = Display.getCurrent();
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
85 if (display is null) {
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
86 display = Display.getDefault ();
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
87 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
88
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
89 FONTDATA_ARRAY_DEFAULT_DEFAULT_ = display.getSystemFont().getFontData();
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
90 FONTDATA_ARRAY_DEFAULT_DEFAULT_initialized = true;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
91 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
92 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
93 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
94 return FONTDATA_ARRAY_DEFAULT_DEFAULT_;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
95 }
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
96
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
97 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
98 * The default-default value for <code>FontData</code> preferences.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
99 */
93
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
100 private static FontData FONTDATA_DEFAULT_DEFAULT_;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
101 private static bool FONTDATA_DEFAULT_DEFAULT_initialized = false;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
102 public static FontData FONTDATA_DEFAULT_DEFAULT(){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
103 if( !FONTDATA_DEFAULT_DEFAULT_initialized ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
104 FONTDATA_ARRAY_DEFAULT_DEFAULT();
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
105 synchronized( PreferenceConverter.classinfo ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
106 if( !FONTDATA_DEFAULT_DEFAULT_initialized ){
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
107 /**
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
108 * The default-default value for <code>FontData</code> preferences.
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
109 * This is left in for compatibility purposes. It is recommended that
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
110 * FONTDATA_ARRAY_DEFAULT_DEFAULT is actually used.
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
111 */
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
112
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
113 FONTDATA_DEFAULT_DEFAULT_ = FONTDATA_ARRAY_DEFAULT_DEFAULT()[0];
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
114 FONTDATA_DEFAULT_DEFAULT_initialized = true;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
115 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
116 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
117 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
118 return FONTDATA_DEFAULT_DEFAULT_;
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
119 }
eb3ef3b7e244 Fix: change to lazy intialization, to prevent Display creation too early.
Frank Benoit <benoit@tionex.de>
parents: 90
diff changeset
120
34
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
121 static this() {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
122 POINT_DEFAULT_DEFAULT = new Point(0, 0);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
123 RECTANGLE_DEFAULT_DEFAULT = new Rectangle(0,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
124 0, 0, 0);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
125 COLOR_DEFAULT_DEFAULT = new RGB(0, 0, 0);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
126 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
127
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
128 /* (non-Javadoc)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
129 * private constructor to prevent instantiation.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
130 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
131 private this() {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
132 //no-op
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
133 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
134
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
135 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
136 * Helper method to construct a color from the given string.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
137 * @param value the indentifier for the color
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
138 * @return RGB
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
139 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
140 private static RGB basicGetColor(String value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
141
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
142 if (IPreferenceStore.STRING_DEFAULT_DEFAULT.equals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
143 return COLOR_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
144 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
145
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
146 RGB color = StringConverter.asRGB(value, null);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
147 if (color is null) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
148 return COLOR_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
149 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
150 return color;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
151 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
152
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
153 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
154 * Helper method to construct a <code>FontData</code> from the given string.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
155 * String is in the form FontData;FontData; in order that
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
156 * multiple FontDatas can be defined.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
157 * @param value the identifier for the font
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
158 * @return FontData[]
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
159 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
160 * @since 3.0
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
161 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
162 public static FontData[] basicGetFontData(String value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
163 if (IPreferenceStore.STRING_DEFAULT_DEFAULT.equals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
164 return FONTDATA_ARRAY_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
165 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
166
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
167 //Read in all of them to get the value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
168 auto tokens = tango.text.Util.delimit( value, ENTRY_SEPARATOR);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
169 int numTokens = tokens.length;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
170 FontData[] fontData = new FontData[numTokens];
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
171
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
172 for (int i = 0; i < numTokens; i++) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
173 try {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
174 fontData[i] = new FontData(tokens[i]);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
175 } catch (DWTException error) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
176 return FONTDATA_ARRAY_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
177 } catch (IllegalArgumentException error) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
178 return FONTDATA_ARRAY_DEFAULT_DEFAULT;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
179 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
180 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
181 return fontData;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
182 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
183
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
184 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
185 * Reads the supplied string and returns its corresponding
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
186 * FontData. If it cannot be read then the default FontData
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
187 * will be returned.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
188 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
189 * @param fontDataValue the string value for the font data
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
190 * @return the font data
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
191 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
192 public static FontData[] readFontData(String fontDataValue) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
193 return basicGetFontData(fontDataValue);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
194 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
195
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
196 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
197 * Helper method to construct a point from the given string.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
198 * @param value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
199 * @return Point
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
200 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
201 private static Point basicGetPoint(String value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
202 Point dp = new Point(POINT_DEFAULT_DEFAULT.x, POINT_DEFAULT_DEFAULT.y);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
203 if (IPreferenceStore.STRING_DEFAULT_DEFAULT.equals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
204 return dp;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
205 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
206 return StringConverter.asPoint(value, dp);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
207 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
208
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
209 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
210 * Helper method to construct a rectangle from the given string.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
211 * @param value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
212 * @return Rectangle
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
213 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
214 private static Rectangle basicGetRectangle(String value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
215 // We can't just return RECTANGLE_DEFAULT_DEFAULT because
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
216 // a rectangle object doesn't have value semantik.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
217 Rectangle dr = new Rectangle(RECTANGLE_DEFAULT_DEFAULT.x,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
218 RECTANGLE_DEFAULT_DEFAULT.y, RECTANGLE_DEFAULT_DEFAULT.width,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
219 RECTANGLE_DEFAULT_DEFAULT.height);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
220
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
221 if (IPreferenceStore.STRING_DEFAULT_DEFAULT.equals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
222 return dr;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
223 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
224 return StringConverter.asRectangle(value, dr);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
225 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
226
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
227 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
228 * Returns the current value of the color-valued preference with the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
229 * given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
230 * Returns the default-default value (<code>COLOR_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
231 * if there is no preference with the given name, or if the current value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
232 * cannot be treated as a color.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
233 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
234 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
235 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
236 * @return the color-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
237 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
238 public static RGB getColor(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
239 return basicGetColor(store.getString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
240 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
241
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
242 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
243 * Returns the default value for the color-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
244 * with the given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
245 * Returns the default-default value (<code>COLOR_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
246 * is no default preference with the given name, or if the default
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
247 * value cannot be treated as a color.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
248 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
249 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
250 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
251 * @return the default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
252 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
253 public static RGB getDefaultColor(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
254 return basicGetColor(store.getDefaultString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
255 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
256
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
257 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
258 * Returns the default value array for the font-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
259 * with the given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
260 * Returns the default-default value (<code>FONTDATA_ARRAY_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
261 * is no default preference with the given name, or if the default
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
262 * value cannot be treated as font data.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
263 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
264 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
265 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
266 * @return the default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
267 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
268 public static FontData[] getDefaultFontDataArray(IPreferenceStore store,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
269 String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
270 return basicGetFontData(store.getDefaultString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
271 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
272
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
273 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
274 * Returns a single default value for the font-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
275 * with the given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
276 * Returns the default-default value (<code>FONTDATA_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
277 * is no default preference with the given name, or if the default
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
278 * value cannot be treated as font data.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
279 * This method is provided for backwards compatibility. It is
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
280 * recommended that <code>getDefaultFontDataArray</code> is
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
281 * used instead.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
282 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
283 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
284 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
285 * @return the default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
286 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
287 public static FontData getDefaultFontData(IPreferenceStore store,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
288 String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
289 return getDefaultFontDataArray(store, name)[0];
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
290 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
291
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
292 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
293 * Returns the default value for the point-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
294 * with the given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
295 * Returns the default-default value (<code>POINT_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
296 * is no default preference with the given name, or if the default
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
297 * value cannot be treated as a point.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
298 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
299 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
300 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
301 * @return the default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
302 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
303 public static Point getDefaultPoint(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
304 return basicGetPoint(store.getDefaultString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
305 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
306
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
307 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
308 * Returns the default value for the rectangle-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
309 * with the given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
310 * Returns the default-default value (<code>RECTANGLE_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
311 * is no default preference with the given name, or if the default
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
312 * value cannot be treated as a rectangle.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
313 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
314 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
315 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
316 * @return the default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
317 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
318 public static Rectangle getDefaultRectangle(IPreferenceStore store,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
319 String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
320 return basicGetRectangle(store.getDefaultString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
321 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
322
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
323 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
324 * Returns the current value of the font-valued preference with the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
325 * given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
326 * Returns the default-default value (<code>FONTDATA_ARRAY_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
327 * if there is no preference with the given name, or if the current value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
328 * cannot be treated as font data.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
329 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
330 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
331 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
332 * @return the font-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
333 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
334 public static FontData[] getFontDataArray(IPreferenceStore store,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
335 String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
336 return basicGetFontData(store.getString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
337 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
338
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
339 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
340 * Returns the current value of the first entry of the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
341 * font-valued preference with the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
342 * given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
343 * Returns the default-default value (<code>FONTDATA_ARRAY_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
344 * if there is no preference with the given name, or if the current value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
345 * cannot be treated as font data.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
346 * This API is provided for backwards compatibility. It is
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
347 * recommended that <code>getFontDataArray</code> is used instead.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
348 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
349 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
350 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
351 * @return the font-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
352 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
353 public static FontData getFontData(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
354 return getFontDataArray(store, name)[0];
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
355 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
356
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
357 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
358 * Returns the current value of the point-valued preference with the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
359 * given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
360 * Returns the default-default value (<code>POINT_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
361 * if there is no preference with the given name, or if the current value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
362 * cannot be treated as a point.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
363 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
364 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
365 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
366 * @return the point-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
367 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
368 public static Point getPoint(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
369 return basicGetPoint(store.getString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
370 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
371
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
372 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
373 * Returns the current value of the rectangle-valued preference with the
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
374 * given name in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
375 * Returns the default-default value (<code>RECTANGLE_DEFAULT_DEFAULT</code>)
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
376 * if there is no preference with the given name, or if the current value
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
377 * cannot be treated as a rectangle.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
378 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
379 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
380 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
381 * @return the rectangle-valued preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
382 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
383 public static Rectangle getRectangle(IPreferenceStore store, String name) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
384 return basicGetRectangle(store.getString(name));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
385 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
386
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
387 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
388 * Sets the default value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
389 * in the given preference store. As FontDatas are stored as
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
390 * arrays this method is only provided for backwards compatibility.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
391 * Use <code>setDefault(IPreferenceStore, String, FontData[])</code>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
392 * instead.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
393 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
394 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
395 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
396 * @param value the new default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
397 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
398 public static void setDefault(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
399 FontData value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
400 FontData[] fontDatas = new FontData[1];
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
401 fontDatas[0] = value;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
402 setDefault(store, name, fontDatas);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
403 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
404
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
405 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
406 * Sets the default value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
407 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
408 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
409 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
410 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
411 * @param value the new default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
412 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
413 public static void setDefault(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
414 FontData[] value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
415 store.setDefault(name, getStoredRepresentation(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
416 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
417
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
418 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
419 * Sets the default value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
420 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
421 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
422 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
423 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
424 * @param value the new default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
425 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
426 public static void setDefault(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
427 Point value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
428 store.setDefault(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
429 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
430
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
431 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
432 * Sets the default value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
433 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
434 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
435 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
436 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
437 * @param value the new default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
438 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
439 public static void setDefault(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
440 Rectangle value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
441 store.setDefault(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
442 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
443
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
444 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
445 * Sets the default value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
446 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
447 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
448 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
449 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
450 * @param value the new default value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
451 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
452 public static void setDefault(IPreferenceStore store, String name, RGB value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
453 store.setDefault(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
454 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
455
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
456 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
457 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
458 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
459 * <p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
460 * Included for backwards compatibility. This method is equivalent to
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
461 * </code>setValue(store, name, new FontData[]{value})</code>.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
462 * </p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
463 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
464 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
465 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
466 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
467 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
468 public static void setValue(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
469 FontData value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
470 setValue(store, name, [ value ]);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
471 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
472
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
473 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
474 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
475 * in the given preference store. This method also sets the corresponding
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
476 * key in the JFace font registry to the value and fires a
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
477 * property change event to listeners on the preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
478 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
479 * <p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
480 * Note that this API does not update any other settings that may
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
481 * be dependant upon it. Only the value in the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
482 * and in the font registry is updated.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
483 * </p>
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
484 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
485 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
486 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
487 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
488 * @see #putValue(IPreferenceStore, String, FontData[])
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
489 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
490 public static void setValue(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
491 FontData[] value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
492 FontData[] oldValue = getFontDataArray(store, name);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
493 // see if the font has changed
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
494 if (!Arrays.equals(oldValue, value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
495 store.putValue(name, getStoredRepresentation(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
496 JFaceResources.getFontRegistry().put(name, value);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
497 store.firePropertyChangeEvent(name, new ArrayWrapperT!(FontData)(oldValue), new ArrayWrapperT!(FontData)(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
498 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
499 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
500
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
501 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
502 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
503 * in the given preference store. This method does not update
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
504 * the font registry or fire a property change event.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
505 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
506 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
507 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
508 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
509 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
510 * @see PreferenceConverter#setValue(IPreferenceStore, String, FontData[])
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
511 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
512 public static void putValue(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
513 FontData[] value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
514 FontData[] oldValue = getFontDataArray(store, name);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
515 // see if the font has changed
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
516 if (!Arrays.equals(oldValue, value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
517 store.putValue(name, getStoredRepresentation(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
518 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
519 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
520
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
521 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
522 * Returns the stored representation of the given array of FontData objects.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
523 * The stored representation has the form FontData;FontData;
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
524 * Only includes the non-null entries.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
525 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
526 * @param fontData the array of FontData objects
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
527 * @return the stored representation of the FontData objects
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
528 * @since 3.0
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
529 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
530 public static String getStoredRepresentation(FontData[] fontData) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
531 StringBuffer buffer = new StringBuffer();
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
532 for (int i = 0; i < fontData.length; i++) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
533 if (fontData[i] !is null) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
534 buffer.append(fontData[i].toString());
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
535 buffer.append(ENTRY_SEPARATOR);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
536 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
537 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
538 return buffer.toString();
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
539 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
540
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
541 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
542 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
543 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
544 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
545 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
546 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
547 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
548 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
549 public static void setValue(IPreferenceStore store, String name, Point value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
550 Point oldValue = getPoint(store, name);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
551 if (oldValue is null || !oldValue.opEquals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
552 store.putValue(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
553 store.firePropertyChangeEvent(name, oldValue, value);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
554 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
555 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
556
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
557 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
558 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
559 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
560 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
561 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
562 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
563 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
564 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
565 public static void setValue(IPreferenceStore store, String name,
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
566 Rectangle value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
567 Rectangle oldValue = getRectangle(store, name);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
568 if (oldValue is null || !oldValue.opEquals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
569 store.putValue(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
570 store.firePropertyChangeEvent(name, oldValue, value);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
571 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
572 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
573
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
574 /**
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
575 * Sets the current value of the preference with the given name
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
576 * in the given preference store.
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
577 *
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
578 * @param store the preference store
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
579 * @param name the name of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
580 * @param value the new current value of the preference
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
581 */
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
582 public static void setValue(IPreferenceStore store, String name, RGB value) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
583 RGB oldValue = getColor(store, name);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
584 if (oldValue is null || !oldValue.opEquals(value)) {
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
585 store.putValue(name, StringConverter.asString(value));
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
586 store.firePropertyChangeEvent(name, oldValue, value);
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
587 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
588 }
b3c8e32d406f preference
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
589 }