annotate dwt/internal/Compatibility.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 ce446666f5a2
children 9e715c0a8376
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
1 /*******************************************************************************
259
c0d810de7093 Update SWT 3.4M7 to 3.4
Frank Benoit <benoit@tionex.de>
parents: 240
diff changeset
2 * Copyright (c) 2000, 2007 IBM Corporation and others.
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
108
0f12f6bb9739 author notice
Frank Benoit <benoit@tionex.de>
parents: 71
diff changeset
10 * Port to the D programming language:
0f12f6bb9739 author notice
Frank Benoit <benoit@tionex.de>
parents: 71
diff changeset
11 * Frank Benoit <benoit@tionex.de>
0
c8ad75f8819e first import
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.internal.Compatibility;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
15 import dwt.dwthelper.utils;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16 /+
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
17 import java.io.File;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 import java.text.MessageFormat;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19 import java.util.MissingResourceException;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 import java.util.ResourceBundle;
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
21 import java.util.zip.DeflaterOutputStream;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22 import java.util.zip.InflaterInputStream;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 +/
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
25 import dwt.DWT;
12
0c78fa47d476 helper classes
Frank Benoit <benoit@tionex.de>
parents: 10
diff changeset
26 public import dwt.dwthelper.FileInputStream;
0c78fa47d476 helper classes
Frank Benoit <benoit@tionex.de>
parents: 10
diff changeset
27 public import dwt.dwthelper.FileOutputStream;
0c78fa47d476 helper classes
Frank Benoit <benoit@tionex.de>
parents: 10
diff changeset
28 public import dwt.dwthelper.InflaterInputStream;
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
29 import dwt.dwthelper.BufferedInputStream;
1
088b30eabff3 some events
Frank Benoit <benoit@tionex.de>
parents: 0
diff changeset
30
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
31 import Math = tango.math.Math;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32 import Unicode = tango.text.Unicode;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 import tango.sys.Process;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 * This class is a placeholder for utility methods commonly
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 * used on J2SE platforms but not supported on some J2ME
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 * profiles.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 * It is part of our effort to provide support for both J2SE
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 * and J2ME platforms.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44 * IMPORTANT: some of the methods have been modified from their
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 * J2SE parents. Refer to the description of each method for
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 * specific changes.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 * <ul>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 * <li>Exceptions thrown may differ since J2ME's set of
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 * exceptions is a subset of J2SE's one.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
51 * </li>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 * <li>The range of the mathematic functions is subject to
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53 * change.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54 * </li>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55 * </ul>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
57 public final class Compatibility {
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60 * Returns the PI constant as a double.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62 public static const real PI = Math.PI;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 static const real toRadians = PI / 180;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 * Answers the length of the side adjacent to the given angle
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68 * of a right triangle. In other words, it returns the integer
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69 * conversion of length * cos (angle).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 * IMPORTANT: the j2me version has an additional restriction on
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72 * the argument. length must be between -32767 and 32767 (inclusive).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 * @param angle the angle in degrees
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76 * @param length the length of the triangle's hypotenuse
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 * @return the integer conversion of length * cos (angle)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
78 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
79 public static int cos(int angle, int length) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
80 return cast(int)(Math.cos(angle * toRadians) * length);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
81 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
82
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
83 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
84 * Answers the length of the side opposite to the given angle
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
85 * of a right triangle. In other words, it returns the integer
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
86 * conversion of length * sin (angle).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
87 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
88 * IMPORTANT: the j2me version has an additional restriction on
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
89 * the argument. length must be between -32767 and 32767 (inclusive).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
90 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
91 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
92 * @param angle the angle in degrees
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
93 * @param length the length of the triangle's hypotenuse
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
94 * @return the integer conversion of length * sin (angle)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
95 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
96 public static int sin(int angle, int length) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
97 return cast(int)(Math.sin(angle * toRadians) * length);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
98 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
99
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
100 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
101 * Answers the most negative (i.e. closest to negative infinity)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
102 * integer value which is greater than the number obtained by dividing
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
103 * the first argument p by the second argument q.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
104 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
105 * @param p numerator
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
106 * @param q denominator (must be different from zero)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
107 * @return the ceiling of the rational number p / q.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
108 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
109 public static int ceil(int p, int q) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
110 return cast(int)Math.ceil(cast(float)p / q);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
111 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
112
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
113 /**
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
114 * Answers whether the indicated file exists or not.
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
115 *
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
116 * @param parent the file's parent directory
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
117 * @param child the file's name
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
118 * @return true if the file exists
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
119 */
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
120 public static bool fileExists(String parent, String child) {
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
121 return (new File (parent, child)).exists();
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
122 }
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
123
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
124 /**
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
125 * Answers the most positive (i.e. closest to positive infinity)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
126 * integer value which is less than the number obtained by dividing
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
127 * the first argument p by the second argument q.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
128 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
129 * @param p numerator
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
130 * @param q denominator (must be different from zero)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
131 * @return the floor of the rational number p / q.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
132 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
133 public static int floor(int p, int q) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
134 return cast(int)Math.floor(cast(double)p / q);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
135 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
136
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
137 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
138 * Answers the result of rounding to the closest integer the number obtained
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
139 * by dividing the first argument p by the second argument q.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
140 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
141 * IMPORTANT: the j2me version has an additional restriction on
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
142 * the arguments. p must be within the range 0 - 32767 (inclusive).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
143 * q must be within the range 1 - 32767 (inclusive).
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
144 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
145 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
146 * @param p numerator
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
147 * @param q denominator (must be different from zero)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
148 * @return the closest integer to the rational number p / q
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
149 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
150 public static int round(int p, int q) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
151 return cast(int)Math.round(cast(float)p / q);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
152 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
153
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
154 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
155 * Returns 2 raised to the power of the argument.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
156 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
157 * @param n an int value between 0 and 30 (inclusive)
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
158 * @return 2 raised to the power of the argument
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
159 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
160 * @exception IllegalArgumentException <ul>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
161 * <li>ERROR_INVALID_RANGE - if the argument is not between 0 and 30 (inclusive)</li>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
162 * </ul>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
163 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
164 public static int pow2(int n) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
165 if (n >= 1 && n <= 30)
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
166 return 2 << (n - 1);
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
167 else if (n != 0) {
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
168 DWT.error(DWT.ERROR_INVALID_RANGE);
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
169 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
170 return 1;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
171 }
4
94c5d794407f more simple classes
Frank Benoit <benoit@tionex.de>
parents: 1
diff changeset
172
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
173 /**
240
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
174 * Create an DeflaterOutputStream if such things are supported.
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
175 *
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
176 * @param stream the output stream
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
177 * @return a deflater stream or <code>null</code>
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
178 * @exception IOException
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
179 *
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
180 * @since 3.4
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
181 */
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
182 public static OutputStream newDeflaterOutputStream(OutputStream stream) {
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
183 implMissing(__FILE__,__LINE__);
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
184 return null;
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
185 //DWT_TODO return new DeflaterOutputStream(stream);
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
186 }
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
187
ce446666f5a2 Update to SWT 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 238
diff changeset
188 /**
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
189 * Open a file if such things are supported.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
190 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
191 * @param filename the name of the file to open
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
192 * @return a stream on the file if it could be opened.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
193 * @exception IOException
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
194 */
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
195 public static InputStream newFileInputStream(String filename) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
196 return new FileInputStream(filename);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
197 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
198
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
199 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
200 * Open a file if such things are supported.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
201 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
202 * @param filename the name of the file to open
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
203 * @return a stream on the file if it could be opened.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
204 * @exception IOException
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
205 */
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
206 public static OutputStream newFileOutputStream(String filename) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
207 return new FileOutputStream(filename);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
208 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
209
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
210 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
211 * Create an InflaterInputStream if such things are supported.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
212 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
213 * @param stream the input stream
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
214 * @return a inflater stream or <code>null</code>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
215 * @exception IOException
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
216 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
217 * @since 3.3
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
218 */
12
0c78fa47d476 helper classes
Frank Benoit <benoit@tionex.de>
parents: 10
diff changeset
219 public static InflaterInputStream newInflaterInputStream(InputStream stream) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
220 return new InflaterInputStream(stream);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
221 }
4
94c5d794407f more simple classes
Frank Benoit <benoit@tionex.de>
parents: 1
diff changeset
222
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
223 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
224 * Answers whether the character is a letter.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
225 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
226 * @param c the character
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
227 * @return true when the character is a letter
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
228 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
229 public static bool isLetter(dchar c) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
230 return Unicode.isLetter(c);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
231 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
232
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
233 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
234 * Answers whether the character is a letter or a digit.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
235 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
236 * @param c the character
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
237 * @return true when the character is a letter or a digit
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
238 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
239 public static bool isLetterOrDigit(dchar c) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
240 return Unicode.isLetterOrDigit(c);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
241 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
242
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
243 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
244 * Answers whether the character is a Unicode space character.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
245 *
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
246 * @param c the character
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
247 * @return true when the character is a Unicode space character
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
248 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
249 public static bool isSpaceChar(dchar c) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
250 return Unicode.isSpace(c);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
251 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
252
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
253 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
254 * Answers whether the character is a whitespace character.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
255 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
256 * @param c the character to test
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
257 * @return true if the character is whitespace
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
258 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
259 public static bool isWhitespace(dchar c) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
260 return Unicode.isWhitespace(c);
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
261 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
262
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
263 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
264 * Execute a program in a separate platform process if the
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
265 * underlying platform support this.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
266 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
267 * The new process inherits the environment of the caller.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
268 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
269 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
270 * @param prog the name of the program to execute
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
271 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
272 * @exception ProcessException
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
273 * if the program cannot be executed
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
274 */
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
275 public static void exec(String prog) {
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
276 auto proc = new Process( prog );
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
277 proc.execute;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
278 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
279
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
280 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
281 * Execute progArray[0] in a separate platform process if the
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
282 * underlying platform support this.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
283 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
284 * The new process inherits the environment of the caller.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
285 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
286 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
287 * @param progArray array containing the program to execute and its arguments
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
288 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
289 * @exception ProcessException
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
290 * if the program cannot be executed
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
291 */
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
292 public static void exec(String[] progArray) {
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
293 auto proc = new Process( progArray );
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
294 proc.execute;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
295 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
296 /++ PORTING_LEFT
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
297 private static ResourceBundle msgs = null;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
298
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
299 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
300 * Returns the NLS'ed message for the given argument. This is only being
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
301 * called from DWT.
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
302 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
303 * @param key the key to look up
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
304 * @return the message for the given key
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
305 *
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
306 * @see DWT#getMessage(String)
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
307 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
308 public static String getMessage(String key) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
309 String answer = key;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
310
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
311 if (key == null) {
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
312 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: 46
diff changeset
313 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
314 if (msgs == null) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
315 try {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
316 msgs = ResourceBundle.getBundle("dwt.internal.SWTMessages"); //$NON-NLS-1$
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
317 } catch (MissingResourceException ex) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
318 answer = key + " (no resource bundle)"; //$NON-NLS-1$
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
319 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
320 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
321 if (msgs != null) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
322 try {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
323 answer = msgs.getString(key);
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
324 } catch (MissingResourceException ex2) {}
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
325 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
326 return answer;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
327 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
328
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
329 public static String getMessage(String key, Object[] args) {
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
330 String answer = key;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
331
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
332 if (key == null || args == null) {
71
295b29fc7d13 Renamed SWT to DWT
Frank Benoit <benoit@tionex.de>
parents: 59
diff changeset
333 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: 46
diff changeset
334 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
335 if (msgs == null) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
336 try {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
337 msgs = ResourceBundle.getBundle("dwt.internal.SWTMessages"); //$NON-NLS-1$
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
338 } catch (MissingResourceException ex) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
339 answer = key + " (no resource bundle)"; //$NON-NLS-1$
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
340 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
341 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
342 if (msgs != null) {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
343 try {
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
344 MessageFormat formatter = new MessageFormat("");
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
345 formatter.applyPattern(msgs.getString(key));
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
346 answer = formatter.format(args);
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
347 } catch (MissingResourceException ex2) {}
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
348 }
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
349 return answer;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
350 }
46
8015c460f713 Synchronizer
Frank Benoit <benoit@tionex.de>
parents: 12
diff changeset
351 ++/
8015c460f713 Synchronizer
Frank Benoit <benoit@tionex.de>
parents: 12
diff changeset
352
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
353
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
354 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
355 * Interrupt the current thread.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
356 * <p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
357 * Note that this is not available on CLDC.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
358 * </p>
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
359 */
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
360 public static void interrupt() {
46
8015c460f713 Synchronizer
Frank Benoit <benoit@tionex.de>
parents: 12
diff changeset
361 //PORTING_FIXME: how to implement??
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
362 //Thread.currentThread().interrupt();
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
363 }
46
8015c460f713 Synchronizer
Frank Benoit <benoit@tionex.de>
parents: 12
diff changeset
364
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
365 /**
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
366 * Compares two instances of class String ignoring the case of the
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
367 * characters and answers if they are equal.
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
368 *
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
369 * @param s1 string
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
370 * @param s2 string
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
371 * @return true if the two instances of class String are equal
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
372 */
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
373 public static bool equalsIgnoreCase(String s1, String s2) {
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
374 String s1b = new char[ s1.length ];
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
375 String s2b = new char[ s1.length ];
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
376 scope(exit){
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
377 delete s1b;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
378 delete s2b;
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
379 }
238
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
380 String s1c = Unicode.toFold( s1, s1b );
380bad9f6852 reverted char[] to String
Frank Benoit <benoit@tionex.de>
parents: 108
diff changeset
381 String s2c = Unicode.toFold( s2, s2b );
59
8cec8f536af3 All D sources complete gvim retab (4 spaces), bug with Composite moveAbove/moveBelow fixed.
Frank Benoit <benoit@tionex.de>
parents: 46
diff changeset
382 return s1c == s2c;
0
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
383 }
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
384
c8ad75f8819e first import
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
385 }