blob: b1b141637515de0d98ee1d3993f49d4b471fb301 [file] [log] [blame]
package org.bouncycastle.asn1.x509;
/**
* class for breaking up an X500 Name into it's component tokens, ala
* java.util.StringTokenizer. We need this class as some of the
* lightweight Java environment don't support classes like
* StringTokenizer.
* @deprecated use X500NameTokenizer
*/
public class X509NameTokenizer
{
private String value;
private int index;
private char separator;
private StringBuffer buf = new StringBuffer();
public X509NameTokenizer(
String oid)
{
this(oid, ',');
}
public X509NameTokenizer(
String oid,
char separator)
{
this.value = oid;
this.index = -1;
this.separator = separator;
}
public boolean hasMoreTokens()
{
return (index != value.length());
}
public String nextToken()
{
if (index == value.length())
{
return null;
}
int end = index + 1;
boolean quoted = false;
boolean escaped = false;
buf.setLength(0);
while (end != value.length())
{
char c = value.charAt(end);
if (c == '"')
{
if (!escaped)
{
quoted = !quoted;
}
buf.append(c);
escaped = false;
}
else
{
if (escaped || quoted)
{
buf.append(c);
escaped = false;
}
else if (c == '\\')
{
buf.append(c);
escaped = true;
}
else if (c == separator)
{
break;
}
else
{
// BEGIN Android-added: Unknown reason
// This was previously marked with the comment "copied from a newer version
// of BouncyCastle", but I couldn't find any evidence that it ever was included
// in any version of BC
if (c == '#' && buf.charAt(buf.length() - 1) == '=')
{
buf.append('\\');
}
else if (c == '+' && separator != '+')
{
buf.append('\\');
}
// END Android-added: Unknown reason
buf.append(c);
}
}
end++;
}
index = end;
return buf.toString();
}
}