-
Notifications
You must be signed in to change notification settings - Fork 2k
Expand file tree
/
Copy pathMissingLocaleArgument.qhelp
More file actions
51 lines (37 loc) · 1.78 KB
/
MissingLocaleArgument.qhelp
File metadata and controls
51 lines (37 loc) · 1.78 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!DOCTYPE qhelp PUBLIC
"-//Semmle//qhelp//EN"
"qhelp.dtd">
<qhelp>
<overview>
<p>
The parameterless versions of <code>String.toUpperCase()</code> and <code>String.toLowerCase()</code> use the default locale of the Java Virtual Machine when
transforming strings. This can cause unexpected behavior for certain locales.
</p>
</overview>
<recommendation>
<p>Use the corresponding methods with explicit locale parameters to ensure that the results are consistent
across all locales. For example:</p>
<p><code>System.out.println("I".toLowerCase(java.util.Locale.ENGLISH));</code></p>
<p>prints <code>i</code>, regardless of the default locale.</p>
</recommendation>
<example>
<p>In the following example, the calls to the parameterless functions may return different strings
for different locales. For example, if the default locale is ENGLISH, the function <code>toLowerCase()</code>
converts a capital <code>I</code> to <code>i</code>; if the default locale is TURKISH, the function
<code>toLowerCase()</code> converts a capital <code>I</code> to the Unicode Character "Latin small
letter dotless i" (U+0131) (<a href="http://character-code.com/turkish-html-codes.php">Turkish HTML
Codes, Unicode Hexadecimal & HTML Names</a>).
</p>
<p>To ensure that an English string is returned, regardless of the default locale, the example shows
how to call <code>toLowerCase</code> and pass <code>locale.ENGLISH</code> as the argument. (This
assumes that the text is English. If the text is Turkish, you should pass
<code>locale.TURKISH</code> as the argument.)</p>
<sample src="MissingLocaleArgument.java" />
</example>
<references>
<li>
Java API Documentation:
<a href="http://java.sun.com/javase/6/docs/api/java/lang/String.html#toUpperCase()">String.toUpperCase()</a>.
</li>
</references>
</qhelp>