java.awt.font
Class NumericShaper
- Serializable
This class handles numeric shaping. A shaper can either be contextual
or not. A non-contextual shaper will always translate ASCII digits
in its input into the target Unicode range. A contextual shaper will
change the target Unicode range depending on the characters it has
previously processed.
static int | ALL_RANGES - Convenience constant representing all the valid Unicode ranges.
|
static int | ARABIC - Constant representing the Unicode ARABIC range.
|
static int | BENGALI - Constant representing the Unicode BENGALI range.
|
static int | DEVANAGARI - Constant representing the Unicode DEVANAGARI range.
|
static int | EASTERN_ARABIC - Constant representing the Unicode extended arabic range.
|
static int | ETHIOPIC - Constant representing the Unicode ETHIOPIC range.
|
static int | EUROPEAN - Constant representing the Unicode EUROPEAN range.
|
static int | GUJARATI - Constant representing the Unicode GUJARATI range.
|
static int | GURMUKHI - Constant representing the Unicode GURMUKHI range.
|
static int | KANNADA - Constant representing the Unicode KANNADA range.
|
static int | KHMER - Constant representing the Unicode KHMER range.
|
static int | LAO - Constant representing the Unicode LAO range.
|
static int | MALAYALAM - Constant representing the Unicode MALAYALAM range.
|
static int | MONGOLIAN - Constant representing the Unicode MONGOLIAN range.
|
static int | MYANMAR - Constant representing the Unicode MYANMAR range.
|
static int | ORIYA - Constant representing the Unicode ORIYA range.
|
static int | TAMIL - Constant representing the Unicode TAMIL range.
|
static int | TELUGU - Constant representing the Unicode TELUGU range.
|
static int | THAI - Constant representing the Unicode THAI range.
|
static int | TIBETAN - Constant representing the Unicode TIBETAN range.
|
boolean | equals(Object obj) - Determine whether this Object is semantically equal
to another Object.
|
static NumericShaper | getContextualShaper(int ranges) - Return a contextual shaper which can shape to any of the indicated
languages.
|
static NumericShaper | getContextualShaper(int ranges, int defaultContext) - Return a contextual shaper which can shape to any of the indicated
languages.
|
int | getRanges() - Return an integer representing all the languages for which this
shaper will shape.
|
static NumericShaper | getShaper(int singleRange) - Return a non-contextual shaper which can shape to a single range.
|
int | hashCode() - Get a value that represents this Object, as uniquely as
possible within the confines of an int.
|
boolean | isContextual() - Return true if this shaper is contextual, false if it is not.
|
void | shape(char[] text, int start, int count) - Shape the text in the given array.
|
void | shape(char[] text, int start, int count, int context) - Shape the given text, using the indicated initial context.
|
String | toString() - Convert this Object to a human-readable String.
|
clone , equals , extends Object> getClass , finalize , hashCode , notify , notifyAll , toString , wait , wait , wait |
ALL_RANGES
public static final int ALL_RANGES
Convenience constant representing all the valid Unicode ranges.
ARABIC
public static final int ARABIC
Constant representing the Unicode ARABIC range. Shaping done
using this range will translate to the arabic decimal characters.
Use EASTERN_ARABIC if you want to shape to the eastern arabic
(also known as the extended arabic) decimal characters.
BENGALI
public static final int BENGALI
Constant representing the Unicode BENGALI range.
DEVANAGARI
public static final int DEVANAGARI
Constant representing the Unicode DEVANAGARI range.
EASTERN_ARABIC
public static final int EASTERN_ARABIC
Constant representing the Unicode extended arabic range.
In Unicode there are two different sets of arabic digits;
this selects the extended or eastern set.
ETHIOPIC
public static final int ETHIOPIC
Constant representing the Unicode ETHIOPIC range. Note that
there is no digit zero in this range; an ASCII digit zero
is left unchanged when shaping to this range.
EUROPEAN
public static final int EUROPEAN
Constant representing the Unicode EUROPEAN range. For
contextual shaping purposes, characters in the various
extended Latin character blocks are recognized as EUROPEAN.
GUJARATI
public static final int GUJARATI
Constant representing the Unicode GUJARATI range.
GURMUKHI
public static final int GURMUKHI
Constant representing the Unicode GURMUKHI range.
KANNADA
public static final int KANNADA
Constant representing the Unicode KANNADA range.
KHMER
public static final int KHMER
Constant representing the Unicode KHMER range.
LAO
public static final int LAO
Constant representing the Unicode LAO range.
MALAYALAM
public static final int MALAYALAM
Constant representing the Unicode MALAYALAM range.
MONGOLIAN
public static final int MONGOLIAN
Constant representing the Unicode MONGOLIAN range.
MYANMAR
public static final int MYANMAR
Constant representing the Unicode MYANMAR range.
ORIYA
public static final int ORIYA
Constant representing the Unicode ORIYA range.
TAMIL
public static final int TAMIL
Constant representing the Unicode TAMIL range. Note that
there is no digit zero in this range; an ASCII digit zero
is left unchanged when shaping to this range.
TELUGU
public static final int TELUGU
Constant representing the Unicode TELUGU range.
THAI
public static final int THAI
Constant representing the Unicode THAI range.
TIBETAN
public static final int TIBETAN
Constant representing the Unicode TIBETAN range.
equals
public boolean equals(Object obj)
Determine whether this Object is semantically equal
to another Object.
There are some fairly strict requirements on this
method which subclasses must follow:
- It must be transitive. If
a.equals(b)
and
b.equals(c)
, then a.equals(c)
must be true as well. - It must be symmetric.
a.equals(b)
and
b.equals(a)
must have the same value. - It must be reflexive.
a.equals(a)
must
always be true. - It must be consistent. Whichever value a.equals(b)
returns on the first invocation must be the value
returned on all later invocations.
a.equals(null)
must be false.- It must be consistent with hashCode(). That is,
a.equals(b)
must imply
a.hashCode() == b.hashCode()
.
The reverse is not true; two objects that are not
equal may have the same hashcode, but that has
the potential to harm hashing performance.
This is typically overridden to throw a
ClassCastException
if the argument is not comparable to the class performing
the comparison, but that is not a requirement. It is legal
for
a.equals(b)
to be true even though
a.getClass() != b.getClass()
. Also, it
is typical to never cause a
NullPointerException
.
In general, the Collections API (
java.util
) use the
equals
method rather than the
==
operator to compare objects. However,
IdentityHashMap
is an exception to this rule, for its own good reasons.
The default implementation returns
this == o
.
- equals in interface Object
obj
- the Object to compare to
- whether this Object is semantically equal to another
getContextualShaper
public static NumericShaper getContextualShaper(int ranges)
Return a contextual shaper which can shape to any of the indicated
languages. The default initial context for this shaper is EUROPEAN.
ranges
- the ranges to shape to
- a contextual shaper which will target any of these ranges
getContextualShaper
public static NumericShaper getContextualShaper(int ranges,
int defaultContext)
Return a contextual shaper which can shape to any of the indicated
languages. The default initial context for this shaper is given as
an argument.
ranges
- the ranges to shape todefaultContext
- the default initial context
- a contextual shaper which will target any of these ranges
IllegalArgumentException
- if the ranges argument specifies an
unrecognized range, or if the defaultContext argument does not specify
a single valid range
getRanges
public int getRanges()
Return an integer representing all the languages for which this
shaper will shape. The result is taken by "or"ing together
the constants representing the various languages.
getShaper
public static NumericShaper getShaper(int singleRange)
Return a non-contextual shaper which can shape to a single range.
All ASCII digits in the input text are translated to this language.
singleRange
- the target language
- a non-contextual shaper for this language
IllegalArgumentException
- if the argument does not name a
single language, as specified by the constants declared in this class
hashCode
public int hashCode()
Get a value that represents this Object, as uniquely as
possible within the confines of an int.
There are some requirements on this method which
subclasses must follow:
- Semantic equality implies identical hashcodes. In other
words, if
a.equals(b)
is true, then
a.hashCode() == b.hashCode()
must be as well.
However, the reverse is not necessarily true, and two
objects may have the same hashcode without being equal. - It must be consistent. Whichever value o.hashCode()
returns on the first invocation must be the value
returned on all later invocations as long as the object
exists. Notice, however, that the result of hashCode may
change between separate executions of a Virtual Machine,
because it is not invoked on the same object.
Notice that since
hashCode
is used in
Hashtable
and other hashing classes,
a poor implementation will degrade the performance of hashing
(so don't blindly implement it as returning a constant!). Also,
if calculating the hash is time-consuming, a class may consider
caching the results.
The default implementation returns
System.identityHashCode(this)
- hashCode in interface Object
- the hash code for this Object
isContextual
public boolean isContextual()
Return true if this shaper is contextual, false if it is not.
shape
public void shape(char[] text,
int start,
int count)
Shape the text in the given array. The starting context will
be the context passed to the shaper at creation time.
text
- the text to shapestart
- the index of the starting character of the arraycount
- the number of characters in the array
shape
public void shape(char[] text,
int start,
int count,
int context)
Shape the given text, using the indicated initial context.
If this shaper is not a contextual shaper, then the given context
will be ignored.
text
- the text to shapestart
- the index of the first character of the text to shapecount
- the number of characters to shape in the textcontext
- the initial context
toString
public String toString()
Convert this Object to a human-readable String.
There are no limits placed on how long this String
should be or what it should contain. We suggest you
make it as intuitive as possible to be able to place
it into
System.out.println()
and such.
It is typical, but not required, to ensure that this method
never completes abruptly with a
RuntimeException
.
This method will be called when performing string
concatenation with this object. If the result is
null
, string concatenation will instead
use
"null"
.
The default implementation returns
getClass().getName() + "@" +
Integer.toHexString(hashCode())
.
- toString in interface Object
- the String representing this Object, which may be null
NumericShaper.java
Copyright (C) 2003 Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version.