summaryrefslogtreecommitdiff
path: root/libjava/java/text/AttributedStringIterator.java
diff options
context:
space:
mode:
authorMichael Koch <mkoch@gcc.gnu.org>2004-03-11 15:50:34 +0000
committerMichael Koch <mkoch@gcc.gnu.org>2004-03-11 15:50:34 +0000
commit1ce9c63d502d0a3f68d71c05a9186b84664905f5 (patch)
tree5ffe3337a96b462774d05d08e29a368e25801fa4 /libjava/java/text/AttributedStringIterator.java
parentc21a266bf28b4171bae0c953e2eb51b0012eb4f6 (diff)
[multiple changes]
2004-03-11 Dalibor Topic <robilad@kaffe.org> * java/text/AttributedString.java (addAttribute(AttributedCharacterIterator.Attribute,Object,int,int)): Use HashMap instead of Hashtable since value can be null, and you can not store a null value in a Hashtable. 2004-03-11 Guilhem Lavaux <guilhem@kaffe.org> * java/text/AttributedStringIterator.java (getAllAttributesKey): Return only keys concerned by the current iterator. (getAttributes): Use strict inequality for end_index. From-SVN: r79329
Diffstat (limited to 'libjava/java/text/AttributedStringIterator.java')
-rw-r--r--libjava/java/text/AttributedStringIterator.java10
1 files changed, 7 insertions, 3 deletions
diff --git a/libjava/java/text/AttributedStringIterator.java b/libjava/java/text/AttributedStringIterator.java
index d3193382bfd..77c5981703d 100644
--- a/libjava/java/text/AttributedStringIterator.java
+++ b/libjava/java/text/AttributedStringIterator.java
@@ -179,8 +179,12 @@ getAllAttributeKeys()
if (attribs == null)
return(s);
- for (int i = 0; i < attribs.length; i++)
+ for (int i = 0; i < attribs.length; i++)
{
+ if (attribs[i].begin_index > getEndIndex()
+ || attribs[i].end_index <= getBeginIndex())
+ continue;
+
Set key_set = attribs[i].attribs.keySet();
Iterator iter = key_set.iterator();
while (iter.hasNext())
@@ -327,7 +331,7 @@ getAttribute(AttributedCharacterIterator.Attribute attrib)
// Check for attribute match and range match
if (obj.equals(attrib))
if ((ci.getIndex() >= attribs[i].begin_index) &&
- (ci.getIndex() <= attribs[i].end_index))
+ (ci.getIndex() < attribs[i].end_index))
return(attribs[i].attribs.get(obj));
}
}
@@ -351,7 +355,7 @@ getAttributes()
for (int i = 0; i < attribs.length; i++)
{
if ((ci.getIndex() >= attribs[i].begin_index) &&
- (ci.getIndex() <= attribs[i].end_index))
+ (ci.getIndex() < attribs[i].end_index))
m.putAll(attribs[i].attribs);
}