aboutsummaryrefslogtreecommitdiff
path: root/libjava/classpath/java/nio/charset
diff options
context:
space:
mode:
authorAndrew Haley <aph@redhat.com>2016-09-30 16:24:48 +0000
committerAndrew Haley <aph@gcc.gnu.org>2016-09-30 16:24:48 +0000
commit07b78716af6a9d7c9fd1e94d9baf94a52c873947 (patch)
tree3f22b3241c513ad168c8353805614ae1249410f4 /libjava/classpath/java/nio/charset
parenteae993948bae8b788c53772bcb9217c063716f93 (diff)
downloadgcc-07b78716af6a9d7c9fd1e94d9baf94a52c873947.zip
gcc-07b78716af6a9d7c9fd1e94d9baf94a52c873947.tar.gz
gcc-07b78716af6a9d7c9fd1e94d9baf94a52c873947.tar.bz2
Makefile.def: Remove libjava.
2016-09-30 Andrew Haley <aph@redhat.com> * Makefile.def: Remove libjava. * Makefile.tpl: Likewise. * Makefile.in: Regenerate. * configure.ac: Likewise. * configure: Likewise. * gcc/java: Remove. * libjava: Likewise. From-SVN: r240662
Diffstat (limited to 'libjava/classpath/java/nio/charset')
-rw-r--r--libjava/classpath/java/nio/charset/CharacterCodingException.java55
-rw-r--r--libjava/classpath/java/nio/charset/Charset.java402
-rw-r--r--libjava/classpath/java/nio/charset/CharsetDecoder.java317
-rw-r--r--libjava/classpath/java/nio/charset/CharsetEncoder.java369
-rw-r--r--libjava/classpath/java/nio/charset/CoderMalfunctionError.java54
-rw-r--r--libjava/classpath/java/nio/charset/CoderResult.java189
-rw-r--r--libjava/classpath/java/nio/charset/CodingErrorAction.java66
-rw-r--r--libjava/classpath/java/nio/charset/IllegalCharsetNameException.java73
-rw-r--r--libjava/classpath/java/nio/charset/MalformedInputException.java79
-rw-r--r--libjava/classpath/java/nio/charset/UnmappableCharacterException.java73
-rw-r--r--libjava/classpath/java/nio/charset/UnsupportedCharsetException.java69
-rw-r--r--libjava/classpath/java/nio/charset/package.html47
-rw-r--r--libjava/classpath/java/nio/charset/spi/CharsetProvider.java95
-rw-r--r--libjava/classpath/java/nio/charset/spi/package.html46
14 files changed, 0 insertions, 1934 deletions
diff --git a/libjava/classpath/java/nio/charset/CharacterCodingException.java b/libjava/classpath/java/nio/charset/CharacterCodingException.java
deleted file mode 100644
index 05f1e3a..0000000
--- a/libjava/classpath/java/nio/charset/CharacterCodingException.java
+++ /dev/null
@@ -1,55 +0,0 @@
-/* CharacterCodingException.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-import java.io.IOException;
-
-/**
- * @since 1.4
- */
-public class CharacterCodingException extends IOException
-{
- private static final long serialVersionUID = 8421532232154627783L;
-
- /**
- * Creates the exception
- */
- public CharacterCodingException()
- {
- }
-}
diff --git a/libjava/classpath/java/nio/charset/Charset.java b/libjava/classpath/java/nio/charset/Charset.java
deleted file mode 100644
index 1757b82..0000000
--- a/libjava/classpath/java/nio/charset/Charset.java
+++ /dev/null
@@ -1,402 +0,0 @@
-/* Charset.java --
- Copyright (C) 2002, 2004, 2005 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. */
-
-
-package java.nio.charset;
-
-import gnu.classpath.ServiceFactory;
-import gnu.classpath.SystemProperties;
-import gnu.java.nio.charset.Provider;
-import gnu.java.nio.charset.iconv.IconvProvider;
-
-import java.nio.ByteBuffer;
-import java.nio.CharBuffer;
-import java.nio.charset.spi.CharsetProvider;
-import java.util.Collections;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.LinkedHashSet;
-import java.util.Locale;
-import java.util.Set;
-import java.util.SortedMap;
-import java.util.TreeMap;
-
-/**
- * @author Jesse Rosenstock
- * @since 1.4
- * @status updated to 1.5
- */
-public abstract class Charset implements Comparable<Charset>
-{
- private CharsetEncoder cachedEncoder;
- private CharsetDecoder cachedDecoder;
-
- /**
- * Extra Charset providers.
- */
- private static CharsetProvider[] providers;
-
- private final String canonicalName;
- private final String[] aliases;
-
- protected Charset (String canonicalName, String[] aliases)
- {
- checkName (canonicalName);
- if (aliases != null)
- {
- int n = aliases.length;
- for (int i = 0; i < n; ++i)
- checkName (aliases[i]);
- }
-
- cachedEncoder = null;
- cachedDecoder = null;
- this.canonicalName = canonicalName;
- this.aliases = aliases;
- }
-
- /**
- * @throws IllegalCharsetNameException if the name is illegal
- */
- private static void checkName (String name)
- {
- int n = name.length ();
-
- if (n == 0)
- throw new IllegalCharsetNameException (name);
-
- char ch = name.charAt (0);
- if (!(('A' <= ch && ch <= 'Z')
- || ('a' <= ch && ch <= 'z')
- || ('0' <= ch && ch <= '9')))
- throw new IllegalCharsetNameException (name);
-
- for (int i = 1; i < n; ++i)
- {
- ch = name.charAt (i);
- if (!(('A' <= ch && ch <= 'Z')
- || ('a' <= ch && ch <= 'z')
- || ('0' <= ch && ch <= '9')
- || ch == '-' || ch == '.' || ch == ':' || ch == '_'))
- throw new IllegalCharsetNameException (name);
- }
- }
-
- /**
- * Returns the system default charset.
- *
- * This may be set by the user or VM with the file.encoding
- * property.
- *
- * @since 1.5
- */
- public static Charset defaultCharset()
- {
- String encoding;
-
- try
- {
- encoding = SystemProperties.getProperty("file.encoding");
- }
- catch(SecurityException e)
- {
- // Use fallback.
- encoding = "ISO-8859-1";
- }
- catch(IllegalArgumentException e)
- {
- // Use fallback.
- encoding = "ISO-8859-1";
- }
-
- try
- {
- return forName(encoding);
- }
- catch(UnsupportedCharsetException e)
- {
- // Ignore.
- }
- catch(IllegalCharsetNameException e)
- {
- // Ignore.
- }
- catch(IllegalArgumentException e)
- {
- // Ignore.
- }
-
- throw new IllegalStateException("Can't get default charset!");
- }
-
- public static boolean isSupported (String charsetName)
- {
- return charsetForName (charsetName) != null;
- }
-
- /**
- * Returns the Charset instance for the charset of the given name.
- *
- * @param charsetName
- * @return the Charset instance for the indicated charset
- * @throws UnsupportedCharsetException if this VM does not support
- * the charset of the given name.
- * @throws IllegalCharsetNameException if the given charset name is
- * legal.
- * @throws IllegalArgumentException if <code>charsetName</code> is null.
- */
- public static Charset forName (String charsetName)
- {
- // Throws IllegalArgumentException as the JDK does.
- if(charsetName == null)
- throw new IllegalArgumentException("Charset name must not be null.");
-
- Charset cs = charsetForName (charsetName);
- if (cs == null)
- throw new UnsupportedCharsetException (charsetName);
- return cs;
- }
-
- /**
- * Retrieves a charset for the given charset name.
- *
- * @return A charset object for the charset with the specified name, or
- * <code>null</code> if no such charset exists.
- *
- * @throws IllegalCharsetNameException if the name is illegal
- */
- private static Charset charsetForName(String charsetName)
- {
- checkName (charsetName);
- // Try the default provider first
- // (so we don't need to load external providers unless really necessary)
- // if it is an exotic charset try loading the external providers.
- Charset cs = provider().charsetForName(charsetName);
- if (cs == null)
- {
- CharsetProvider[] providers = providers2();
- for (int i = 0; i < providers.length; i++)
- {
- cs = providers[i].charsetForName(charsetName);
- if (cs != null)
- break;
- }
- }
- return cs;
- }
-
- public static SortedMap<String, Charset> availableCharsets()
- {
- TreeMap<String, Charset> charsets
- = new TreeMap(String.CASE_INSENSITIVE_ORDER);
- for (Iterator<Charset> i = provider().charsets(); i.hasNext(); )
- {
- Charset cs = i.next();
- charsets.put(cs.name(), cs);
- }
-
- CharsetProvider[] providers = providers2();
- for (int j = 0; j < providers.length; j++)
- {
- for (Iterator<Charset> i = providers[j].charsets(); i.hasNext(); )
- {
- Charset cs = i.next();
- charsets.put(cs.name(), cs);
- }
- }
-
- return Collections.unmodifiableSortedMap(charsets);
- }
-
- private static CharsetProvider provider()
- {
- String useIconv = SystemProperties.getProperty
- ("gnu.classpath.nio.charset.provider.iconv");
-
- if (useIconv != null)
- return IconvProvider.provider();
-
- return Provider.provider();
- }
-
- /**
- * We need to support multiple providers, reading them from
- * java.nio.charset.spi.CharsetProvider in the resource directory
- * META-INF/services. This returns the "extra" charset providers.
- */
- private static CharsetProvider[] providers2()
- {
- if (providers == null)
- {
- try
- {
- Iterator i = ServiceFactory.lookupProviders(CharsetProvider.class);
- LinkedHashSet set = new LinkedHashSet();
- while (i.hasNext())
- set.add(i.next());
-
- providers = new CharsetProvider[set.size()];
- set.toArray(providers);
- }
- catch (Exception e)
- {
- throw new RuntimeException(e);
- }
- }
- return providers;
- }
-
- public final String name ()
- {
- return canonicalName;
- }
-
- public final Set<String> aliases ()
- {
- if (aliases == null)
- return Collections.<String>emptySet();
-
- // should we cache the aliasSet instead?
- int n = aliases.length;
- HashSet<String> aliasSet = new HashSet<String> (n);
- for (int i = 0; i < n; ++i)
- aliasSet.add (aliases[i]);
- return Collections.unmodifiableSet (aliasSet);
- }
-
- public String displayName ()
- {
- return canonicalName;
- }
-
- public String displayName (Locale locale)
- {
- return canonicalName;
- }
-
- public final boolean isRegistered ()
- {
- return (!canonicalName.startsWith ("x-")
- && !canonicalName.startsWith ("X-"));
- }
-
- public abstract boolean contains (Charset cs);
-
- public abstract CharsetDecoder newDecoder ();
-
- public abstract CharsetEncoder newEncoder ();
-
- public boolean canEncode ()
- {
- return true;
- }
-
- // NB: This implementation serializes different threads calling
- // Charset.encode(), a potential performance problem. It might
- // be better to remove the cache, or use ThreadLocal to cache on
- // a per-thread basis.
- public final synchronized ByteBuffer encode (CharBuffer cb)
- {
- try
- {
- if (cachedEncoder == null)
- {
- cachedEncoder = newEncoder ()
- .onMalformedInput (CodingErrorAction.REPLACE)
- .onUnmappableCharacter (CodingErrorAction.REPLACE);
- } else
- cachedEncoder.reset();
- return cachedEncoder.encode (cb);
- }
- catch (CharacterCodingException e)
- {
- throw new AssertionError (e);
- }
- }
-
- public final ByteBuffer encode (String str)
- {
- return encode (CharBuffer.wrap (str));
- }
-
- // NB: This implementation serializes different threads calling
- // Charset.decode(), a potential performance problem. It might
- // be better to remove the cache, or use ThreadLocal to cache on
- // a per-thread basis.
- public final synchronized CharBuffer decode (ByteBuffer bb)
- {
- try
- {
- if (cachedDecoder == null)
- {
- cachedDecoder = newDecoder ()
- .onMalformedInput (CodingErrorAction.REPLACE)
- .onUnmappableCharacter (CodingErrorAction.REPLACE);
- } else
- cachedDecoder.reset();
-
- return cachedDecoder.decode (bb);
- }
- catch (CharacterCodingException e)
- {
- throw new AssertionError (e);
- }
- }
-
- public final int compareTo (Charset other)
- {
- return canonicalName.compareToIgnoreCase (other.canonicalName);
- }
-
- public final int hashCode ()
- {
- return canonicalName.hashCode ();
- }
-
- public final boolean equals (Object ob)
- {
- if (ob instanceof Charset)
- return canonicalName.equalsIgnoreCase (((Charset) ob).canonicalName);
- else
- return false;
- }
-
- public final String toString ()
- {
- return canonicalName;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/CharsetDecoder.java b/libjava/classpath/java/nio/charset/CharsetDecoder.java
deleted file mode 100644
index cf43feaf..0000000
--- a/libjava/classpath/java/nio/charset/CharsetDecoder.java
+++ /dev/null
@@ -1,317 +0,0 @@
-/* CharsetDecoder.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-import java.nio.ByteBuffer;
-import java.nio.CharBuffer;
-
-/**
- * @author Jesse Rosenstock
- * @since 1.4
- */
-public abstract class CharsetDecoder
-{
- private static final int STATE_RESET = 0;
- private static final int STATE_CODING = 1;
- private static final int STATE_END = 2;
- private static final int STATE_FLUSHED = 3;
-
- private static final String DEFAULT_REPLACEMENT = "\uFFFD";
-
- private final Charset charset;
- private final float averageCharsPerByte;
- private final float maxCharsPerByte;
- private String replacement;
-
- private int state = STATE_RESET;
-
- private CodingErrorAction malformedInputAction
- = CodingErrorAction.REPORT;
- private CodingErrorAction unmappableCharacterAction
- = CodingErrorAction.REPORT;
-
- private CharsetDecoder (Charset cs, float averageCharsPerByte,
- float maxCharsPerByte, String replacement)
- {
- if (averageCharsPerByte <= 0.0f)
- throw new IllegalArgumentException ("Non-positive averageCharsPerByte");
- if (maxCharsPerByte <= 0.0f)
- throw new IllegalArgumentException ("Non-positive maxCharsPerByte");
-
- this.charset = cs;
- this.averageCharsPerByte
- = averageCharsPerByte;
- this.maxCharsPerByte
- = maxCharsPerByte;
- this.replacement = replacement;
- implReplaceWith (replacement);
- }
-
- protected CharsetDecoder (Charset cs, float averageCharsPerByte,
- float maxCharsPerByte)
- {
- this (cs, averageCharsPerByte, maxCharsPerByte, DEFAULT_REPLACEMENT);
- }
-
- public final float averageCharsPerByte ()
- {
- return averageCharsPerByte;
- }
-
- public final Charset charset ()
- {
- return charset;
- }
-
- public final CharBuffer decode (ByteBuffer in)
- throws CharacterCodingException
- {
- // XXX: Sun's Javadoc seems to contradict itself saying an
- // IllegalStateException is thrown "if a decoding operation is already
- // in progress" and also that "it resets this Decoder".
- // Should we check to see that the state is reset, or should we
- // call reset()?
- if (state != STATE_RESET)
- throw new IllegalStateException ();
-
- // REVIEW: Using max instead of average may allocate a very large
- // buffer. Maybe we should do something more efficient?
- int remaining = in.remaining ();
- int n = (int) (remaining * maxCharsPerByte ());
- CharBuffer out = CharBuffer.allocate (n);
-
- if (remaining == 0)
- {
- state = STATE_FLUSHED;
- return out;
- }
-
- CoderResult cr = decode (in, out, true);
- if (cr.isError ())
- cr.throwException ();
-
- cr = flush (out);
- if (cr.isError ())
- cr.throwException ();
-
- reset();
- out.flip ();
-
- // Unfortunately, resizing the actual charbuffer array is required.
- char[] resized = new char[out.remaining()];
- out.get(resized);
- return CharBuffer.wrap(resized);
- }
-
- public final CoderResult decode (ByteBuffer in, CharBuffer out,
- boolean endOfInput)
- {
- int newState = endOfInput ? STATE_END : STATE_CODING;
- // XXX: Need to check for "previous step was an invocation [not] of
- // this method with a value of true for the endOfInput parameter but
- // a return value indicating an incomplete decoding operation"
- // XXX: We will not check the previous return value, just
- // that the previous call passed true for endOfInput
- if (state != STATE_RESET && state != STATE_CODING
- && !(endOfInput && state == STATE_END))
- throw new IllegalStateException ();
- state = newState;
-
- for (;;)
- {
- CoderResult cr;
- try
- {
- cr = decodeLoop (in, out);
- }
- catch (RuntimeException e)
- {
- throw new CoderMalfunctionError (e);
- }
-
- if (cr.isOverflow ())
- return cr;
-
- if (cr.isUnderflow ())
- {
- if (endOfInput && in.hasRemaining ())
- cr = CoderResult.malformedForLength (in.remaining ());
- else
- return cr;
- }
-
- CodingErrorAction action = cr.isMalformed ()
- ? malformedInputAction
- : unmappableCharacterAction;
-
- if (action == CodingErrorAction.REPORT)
- return cr;
-
- if (action == CodingErrorAction.REPLACE)
- {
- if (out.remaining () < replacement.length ())
- return CoderResult.OVERFLOW;
- out.put (replacement);
- }
-
- in.position (in.position () + cr.length ());
- }
- }
-
- protected abstract CoderResult decodeLoop (ByteBuffer in, CharBuffer out);
-
- public Charset detectedCharset ()
- {
- throw new UnsupportedOperationException ();
- }
-
- public final CoderResult flush (CharBuffer out)
- {
- // It seems weird that you can flush after reset, but Sun's javadoc
- // says an IllegalStateException is thrown "If the previous step of the
- // current decoding operation was an invocation neither of the reset
- // method nor ... of the three-argument decode method with a value of
- // true for the endOfInput parameter."
- // Further note that flush() only requires that there not be
- // an IllegalStateException if the previous step was a call to
- // decode with true as the last argument. It does not require
- // that the call succeeded. decode() does require that it succeeded.
- // XXX: test this to see if reality matches javadoc
- if (state != STATE_RESET && state != STATE_END)
- throw new IllegalStateException ();
-
- state = STATE_FLUSHED;
- return implFlush (out);
- }
-
- protected CoderResult implFlush (CharBuffer out)
- {
- return CoderResult.UNDERFLOW;
- }
-
- public final CharsetDecoder onMalformedInput (CodingErrorAction newAction)
- {
- if (newAction == null)
- throw new IllegalArgumentException ("Null action");
-
- malformedInputAction = newAction;
- implOnMalformedInput (newAction);
- return this;
- }
-
- protected void implOnMalformedInput (CodingErrorAction newAction)
- {
- // default implementation does nothing
- }
-
- protected void implOnUnmappableCharacter (CodingErrorAction newAction)
- {
- // default implementation does nothing
- }
-
- protected void implReplaceWith (String newReplacement)
- {
- // default implementation does nothing
- }
-
- protected void implReset ()
- {
- // default implementation does nothing
- }
-
- public boolean isAutoDetecting ()
- {
- return false;
- }
-
- public boolean isCharsetDetected ()
- {
- throw new UnsupportedOperationException ();
- }
-
- public CodingErrorAction malformedInputAction ()
- {
- return malformedInputAction;
- }
-
- public final float maxCharsPerByte ()
- {
- return maxCharsPerByte;
- }
-
- public final CharsetDecoder onUnmappableCharacter
- (CodingErrorAction newAction)
- {
- if (newAction == null)
- throw new IllegalArgumentException ("Null action");
-
- unmappableCharacterAction = newAction;
- implOnUnmappableCharacter (newAction);
- return this;
- }
-
- public final String replacement ()
- {
- return replacement;
- }
-
- public final CharsetDecoder replaceWith (String newReplacement)
- {
- if (newReplacement == null)
- throw new IllegalArgumentException ("Null replacement");
- if (newReplacement.length () == 0)
- throw new IllegalArgumentException ("Empty replacement");
- // XXX: what about maxCharsPerByte?
-
- this.replacement = newReplacement;
- implReplaceWith (newReplacement);
- return this;
- }
-
- public final CharsetDecoder reset ()
- {
- state = STATE_RESET;
- implReset ();
- return this;
- }
-
- public CodingErrorAction unmappableCharacterAction ()
- {
- return unmappableCharacterAction;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/CharsetEncoder.java b/libjava/classpath/java/nio/charset/CharsetEncoder.java
deleted file mode 100644
index 1f079a3..0000000
--- a/libjava/classpath/java/nio/charset/CharsetEncoder.java
+++ /dev/null
@@ -1,369 +0,0 @@
-/* CharsetEncoder.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-import java.nio.ByteBuffer;
-import java.nio.CharBuffer;
-
-/**
- * @author Jesse Rosenstock
- * @since 1.4
- */
-public abstract class CharsetEncoder
-{
- private static final int STATE_RESET = 0;
- private static final int STATE_CODING = 1;
- private static final int STATE_END = 2;
- private static final int STATE_FLUSHED = 3;
-
- private static final byte[] DEFAULT_REPLACEMENT = {(byte)'?'};
-
- private final Charset charset;
- private final float averageBytesPerChar;
- private final float maxBytesPerChar;
- private byte[] replacement;
-
- private int state = STATE_RESET;
-
- private CodingErrorAction malformedInputAction
- = CodingErrorAction.REPORT;
- private CodingErrorAction unmappableCharacterAction
- = CodingErrorAction.REPORT;
-
- protected CharsetEncoder (Charset cs, float averageBytesPerChar,
- float maxBytesPerChar)
- {
- this (cs, averageBytesPerChar, maxBytesPerChar, DEFAULT_REPLACEMENT);
- }
-
- protected CharsetEncoder (Charset cs, float averageBytesPerChar,
- float maxBytesPerChar, byte[] replacement)
- {
- if (averageBytesPerChar <= 0.0f)
- throw new IllegalArgumentException ("Non-positive averageBytesPerChar");
- if (maxBytesPerChar <= 0.0f)
- throw new IllegalArgumentException ("Non-positive maxBytesPerChar");
-
- this.charset = cs;
- this.averageBytesPerChar
- = averageBytesPerChar;
- this.maxBytesPerChar
- = maxBytesPerChar;
- this.replacement = replacement;
- implReplaceWith (replacement);
- }
-
- public final float averageBytesPerChar ()
- {
- return averageBytesPerChar;
- }
-
- public boolean canEncode (char c)
- {
- CharBuffer cb = CharBuffer.allocate (1).put (c);
- cb.flip ();
- return canEncode (cb);
- }
-
- public boolean canEncode (CharSequence cs)
- {
- CharBuffer cb;
- if (cs instanceof CharBuffer)
- cb = ((CharBuffer) cs).duplicate ();
- else
- cb = CharBuffer.wrap (cs);
- return canEncode (cb);
- }
-
- private boolean canEncode (CharBuffer cb)
- {
- // It is an error if a coding operation is "in progress"
- // I take that to mean the state is not reset or flushed.
- // XXX: check "in progress" everywhere
- if (state == STATE_FLUSHED)
- reset ();
- else if (state != STATE_RESET)
- throw new IllegalStateException ();
-
- CodingErrorAction oldMalformedInputAction = malformedInputAction;
- CodingErrorAction oldUnmappableCharacterAction
- = unmappableCharacterAction;
-
- try
- {
- if (oldMalformedInputAction != CodingErrorAction.REPORT)
- onMalformedInput (CodingErrorAction.REPORT);
- if (oldUnmappableCharacterAction != CodingErrorAction.REPORT)
- onUnmappableCharacter (CodingErrorAction.REPORT);
- }
- catch (Exception e)
- {
- return false;
- }
- finally
- {
- if (oldMalformedInputAction != CodingErrorAction.REPORT)
- onMalformedInput (oldMalformedInputAction);
- if (oldUnmappableCharacterAction != CodingErrorAction.REPORT)
- onUnmappableCharacter (oldUnmappableCharacterAction);
- }
-
- return true;
- }
-
- public final Charset charset ()
- {
- return charset;
- }
-
- public final ByteBuffer encode (CharBuffer in)
- throws CharacterCodingException
- {
- // XXX: Sun's Javadoc seems to contradict itself saying an
- // IllegalStateException is thrown "if a decoding operation is already
- // in progress" and also that "it resets this Encoder".
- // Should we check to see that the state is reset, or should we
- // call reset()?
- if (state != STATE_RESET)
- throw new IllegalStateException ();
-
- // REVIEW: Using max instead of average may allocate a very large
- // buffer. Maybe we should do something more efficient?
- int remaining = in.remaining ();
- int n = (int) (remaining * maxBytesPerChar ());
- ByteBuffer out = ByteBuffer.allocate (n);
-
- if (remaining == 0)
- {
- state = STATE_FLUSHED;
- return out;
- }
-
- CoderResult cr = encode (in, out, true);
- if (cr.isError ())
- cr.throwException ();
-
- cr = flush (out);
- if (cr.isError ())
- cr.throwException ();
-
- out.flip ();
-
- // Unfortunately, resizing the actual bytebuffer array is required.
- byte[] resized = new byte[out.remaining()];
- out.get(resized);
- return ByteBuffer.wrap(resized);
- }
-
- public final CoderResult encode (CharBuffer in, ByteBuffer out,
- boolean endOfInput)
- {
- int newState = endOfInput ? STATE_END : STATE_CODING;
- // XXX: Need to check for "previous step was an invocation [not] of
- // this method with a value of true for the endOfInput parameter but
- // a return value indicating an incomplete decoding operation"
- // XXX: We will not check the previous return value, just
- // that the previous call passed true for endOfInput
- if (state != STATE_RESET && state != STATE_CODING
- && !(endOfInput && state == STATE_END))
- throw new IllegalStateException ();
- state = newState;
-
- for (;;)
- {
- CoderResult cr;
- try
- {
- cr = encodeLoop (in, out);
- }
- catch (RuntimeException e)
- {
- throw new CoderMalfunctionError (e);
- }
-
- if (cr.isOverflow ())
- return cr;
-
- if (cr.isUnderflow ())
- {
- if (endOfInput && in.hasRemaining ())
- cr = CoderResult.malformedForLength (in.remaining ());
- else
- return cr;
- }
-
- CodingErrorAction action = cr.isMalformed ()
- ? malformedInputAction
- : unmappableCharacterAction;
-
- if (action == CodingErrorAction.REPORT)
- return cr;
-
- if (action == CodingErrorAction.REPLACE)
- {
- if (out.remaining () < replacement.length)
- return CoderResult.OVERFLOW;
- out.put (replacement);
- }
-
- in.position (in.position () + cr.length ());
- }
- }
-
- protected abstract CoderResult encodeLoop (CharBuffer in, ByteBuffer out);
-
- public final CoderResult flush (ByteBuffer out)
- {
- // It seems weird that you can flush after reset, but Sun's javadoc
- // says an IllegalStateException is thrown "If the previous step of the
- // current decoding operation was an invocation neither of the reset
- // method nor ... of the three-argument encode method with a value of
- // true for the endOfInput parameter."
- // Further note that flush() only requires that there not be
- // an IllegalStateException if the previous step was a call to
- // encode with true as the last argument. It does not require
- // that the call succeeded. encode() does require that it succeeded.
- // XXX: test this to see if reality matches javadoc
- if (state != STATE_RESET && state != STATE_END)
- throw new IllegalStateException ();
-
- state = STATE_FLUSHED;
- return implFlush (out);
- }
-
- protected CoderResult implFlush (ByteBuffer out)
- {
- return CoderResult.UNDERFLOW;
- }
-
- protected void implOnMalformedInput (CodingErrorAction newAction)
- {
- // default implementation does nothing
- }
-
- protected void implOnUnmappableCharacter (CodingErrorAction newAction)
- {
- // default implementation does nothing
- }
-
- protected void implReplaceWith (byte[] newReplacement)
- {
- // default implementation does nothing
- }
-
- protected void implReset ()
- {
- // default implementation does nothing
- }
-
- public boolean isLegalReplacement (byte[] replacement)
- {
- // TODO: cache the decoder
- // error actions will be REPORT after construction
- CharsetDecoder decoder = charset.newDecoder ();
- ByteBuffer bb = ByteBuffer.wrap (replacement);
- CharBuffer cb
- = CharBuffer.allocate ((int) (replacement.length
- * decoder.maxCharsPerByte ()));
- return !decoder.decode (bb, cb, true).isError ();
- }
-
- public CodingErrorAction malformedInputAction ()
- {
- return malformedInputAction;
- }
-
- public final float maxBytesPerChar ()
- {
- return maxBytesPerChar;
- }
-
- public final CharsetEncoder onMalformedInput (CodingErrorAction newAction)
- {
- if (newAction == null)
- throw new IllegalArgumentException ("Null action");
-
- malformedInputAction = newAction;
- implOnMalformedInput (newAction);
- return this;
- }
-
- public CodingErrorAction unmappableCharacterAction ()
- {
- return unmappableCharacterAction;
- }
-
- public final CharsetEncoder onUnmappableCharacter
- (CodingErrorAction newAction)
- {
- if (newAction == null)
- throw new IllegalArgumentException ("Null action");
-
- unmappableCharacterAction = newAction;
- implOnUnmappableCharacter (newAction);
- return this;
- }
-
- public final byte[] replacement ()
- {
- return replacement;
- }
-
- public final CharsetEncoder replaceWith (byte[] newReplacement)
- {
- if (newReplacement == null)
- throw new IllegalArgumentException ("Null replacement");
- if (newReplacement.length == 0)
- throw new IllegalArgumentException ("Empty replacement");
- // XXX: what about maxBytesPerChar?
-
- if (!isLegalReplacement (newReplacement))
- throw new IllegalArgumentException ("Illegal replacement");
-
- this.replacement = newReplacement;
- implReplaceWith (newReplacement);
- return this;
- }
-
- public final CharsetEncoder reset ()
- {
- state = STATE_RESET;
- implReset ();
- return this;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/CoderMalfunctionError.java b/libjava/classpath/java/nio/charset/CoderMalfunctionError.java
deleted file mode 100644
index f7a32d2..0000000
--- a/libjava/classpath/java/nio/charset/CoderMalfunctionError.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/* CoderMalfunctionError.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-/**
- * @since 1.4
- */
-public class CoderMalfunctionError extends Error
-{
- private static final long serialVersionUID = - 1151412348057794301L;
-
- /**
- * Creates the error
- */
- public CoderMalfunctionError(Exception cause)
- {
- super (cause);
- }
-}
diff --git a/libjava/classpath/java/nio/charset/CoderResult.java b/libjava/classpath/java/nio/charset/CoderResult.java
deleted file mode 100644
index b083d84..0000000
--- a/libjava/classpath/java/nio/charset/CoderResult.java
+++ /dev/null
@@ -1,189 +0,0 @@
-/* CoderResult.java --
- Copyright (C) 2002, 2004 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. */
-
-package java.nio.charset;
-
-import java.lang.ref.WeakReference;
-import java.nio.BufferOverflowException;
-import java.nio.BufferUnderflowException;
-import java.util.HashMap;
-
-/**
- * @author Jesse Rosenstock
- * @since 1.4
- */
-public class CoderResult
-{
- private static final int TYPE_MALFORMED = 0;
- private static final int TYPE_OVERFLOW = 1;
- private static final int TYPE_UNDERFLOW = 2;
- private static final int TYPE_UNMAPPABLE = 3;
-
- public static final CoderResult OVERFLOW
- = new CoderResult (TYPE_OVERFLOW, 0);
- public static final CoderResult UNDERFLOW
- = new CoderResult (TYPE_UNDERFLOW, 0);
-
- private static final String[] names
- = { "MALFORMED", "OVERFLOW", "UNDERFLOW", "UNMAPPABLE" };
-
- private static final Cache malformedCache
- = new Cache ()
- {
- protected CoderResult make (int length)
- {
- return new CoderResult (TYPE_MALFORMED, length);
- }
- };
-
- private static final Cache unmappableCache
- = new Cache ()
- {
- protected CoderResult make (int length)
- {
- return new CoderResult (TYPE_UNMAPPABLE, length);
- }
- };
-
- private final int type;
- private final int length;
-
- // Package-private to avoid a trampoline constructor.
- CoderResult (int type, int length)
- {
- this.type = type;
- this.length = length;
- }
-
- public boolean isError ()
- {
- return length > 0;
- }
-
- public boolean isMalformed ()
- {
- return type == TYPE_MALFORMED;
- }
-
- public boolean isOverflow ()
- {
- return type == TYPE_OVERFLOW;
- }
-
- public boolean isUnderflow ()
- {
- return type == TYPE_UNDERFLOW;
- }
-
- public boolean isUnmappable ()
- {
- return type == TYPE_UNMAPPABLE;
- }
-
- public int length ()
- {
- if (length <= 0)
- throw new UnsupportedOperationException ();
- else
- return length;
- }
-
- public static CoderResult malformedForLength (int length)
- {
- return malformedCache.get (length);
- }
-
- public void throwException ()
- throws CharacterCodingException
- {
- switch (type)
- {
- case TYPE_MALFORMED:
- throw new MalformedInputException (length);
- case TYPE_OVERFLOW:
- throw new BufferOverflowException ();
- case TYPE_UNDERFLOW:
- throw new BufferUnderflowException ();
- case TYPE_UNMAPPABLE:
- throw new UnmappableCharacterException (length);
- }
- }
-
- public String toString ()
- {
- String name = names[type];
- return (length > 0) ? name + '[' + length + ']' : name;
- }
-
- public static CoderResult unmappableForLength (int length)
- {
- return unmappableCache.get (length);
- }
-
- private abstract static class Cache
- {
- private final HashMap cache;
-
- // Package-private to avoid a trampoline constructor.
- Cache ()
- {
- cache = new HashMap ();
- }
-
- // Package-private to avoid a trampoline.
- synchronized CoderResult get (int length)
- {
- if (length <= 0)
- throw new IllegalArgumentException ("Non-positive length");
-
- Integer len = Integer.valueOf (length);
- CoderResult cr = null;
- Object o;
- if ((o = cache.get (len)) != null)
- cr = (CoderResult) ((WeakReference) o).get ();
- if (cr == null)
- {
- cr = make (length);
- cache.put (len, new WeakReference (cr));
- }
-
- return cr;
- }
-
- protected abstract CoderResult make (int length);
- }
-}
diff --git a/libjava/classpath/java/nio/charset/CodingErrorAction.java b/libjava/classpath/java/nio/charset/CodingErrorAction.java
deleted file mode 100644
index 3b64030..0000000
--- a/libjava/classpath/java/nio/charset/CodingErrorAction.java
+++ /dev/null
@@ -1,66 +0,0 @@
-/* CodingErrorAction.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-public class CodingErrorAction
-{
- public static final CodingErrorAction IGNORE
- = new CodingErrorAction("ignore");
- public static final CodingErrorAction REPLACE
- = new CodingErrorAction("replace");
- public static final CodingErrorAction REPORT
- = new CodingErrorAction("report");
-
- private final String name;
-
- /**
- * Private constructor only used to create the constant CodingErrorActions.
- */
- private CodingErrorAction(String name)
- {
- this.name = name;
- }
-
- /**
- * Returns the name of the CodingErrorAction.
- */
- public String toString ()
- {
- return name;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/IllegalCharsetNameException.java b/libjava/classpath/java/nio/charset/IllegalCharsetNameException.java
deleted file mode 100644
index 0e05d4d..0000000
--- a/libjava/classpath/java/nio/charset/IllegalCharsetNameException.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/* IllegalCharsetNameException.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-/**
- * @author Michael Koch
- * @since 1.4
- */
-public class IllegalCharsetNameException extends IllegalArgumentException
-{
- /**
- * Compatible with JDK 1.4+
- */
- private static final long serialVersionUID = 1457525358470002989L;
-
- private String charsetName;
-
- /**
- * Creates the exception
- *
- * @param charsetName name of the illegal charset
- */
- public IllegalCharsetNameException (String charsetName)
- {
- super ();
- this.charsetName = charsetName;
- }
-
- /**
- * Retrieves the illegal charset name
- *
- * @return the illegal charset name
- */
- public String getCharsetName ()
- {
- return charsetName;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/MalformedInputException.java b/libjava/classpath/java/nio/charset/MalformedInputException.java
deleted file mode 100644
index 3870b55..0000000
--- a/libjava/classpath/java/nio/charset/MalformedInputException.java
+++ /dev/null
@@ -1,79 +0,0 @@
-/* MalformedInputException.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-/**
- * @since 1.4
- */
-public class MalformedInputException extends CharacterCodingException
-{
- private static final long serialVersionUID = - 3438823399834806194L;
-
- private int inputLength;
-
- /**
- * Creates the exception
- *
- * @param inputLength the position of malformed input in the input stream
- */
- public MalformedInputException (int inputLength)
- {
- super ();
- this.inputLength = inputLength;
- }
-
- /**
- * Retrieves the position of the malformed input in the input stream.
- *
- * @return the position
- */
- public int getInputLength ()
- {
- return inputLength;
- }
-
- /**
- * Returns the detail message string of this throwable
- *
- * @return the message
- */
- public String getMessage ()
- {
- return "Input length = " + inputLength;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/UnmappableCharacterException.java b/libjava/classpath/java/nio/charset/UnmappableCharacterException.java
deleted file mode 100644
index d9cdb49..0000000
--- a/libjava/classpath/java/nio/charset/UnmappableCharacterException.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/* UnmappableCharacterException.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-/**
- * @since 1.4
- */
-public class UnmappableCharacterException extends CharacterCodingException
-{
- private static final long serialVersionUID = - 7026962371537706123L;
-
- private int inputLength;
-
- /**
- * Creates the exception
- */
- public UnmappableCharacterException (int inputLength)
- {
- super ();
- this.inputLength = inputLength;
- }
-
- /**
- * Retrieves the illegal charset name
- */
- public int getInputLength ()
- {
- return inputLength;
- }
-
- /**
- * Returns the detail message string of this throwable
- */
- public String getMessage ()
- {
- return "Input length = " + inputLength;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/UnsupportedCharsetException.java b/libjava/classpath/java/nio/charset/UnsupportedCharsetException.java
deleted file mode 100644
index c4f9d17..0000000
--- a/libjava/classpath/java/nio/charset/UnsupportedCharsetException.java
+++ /dev/null
@@ -1,69 +0,0 @@
-/* UnsupportedCharsetException.java --
- Copyright (C) 2002 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. */
-
-package java.nio.charset;
-
-/**
- * @author Michael Koch
- * @since 1.4
- */
-public class UnsupportedCharsetException extends IllegalArgumentException
-{
- /**
- * Compatible with JDK 1.4+
- */
- private static final long serialVersionUID = 1490765524727386367L;
-
- String charsetName;
-
- /**
- * Creates the exception
- */
- public UnsupportedCharsetException (String charsetName)
- {
- super ();
- this.charsetName = charsetName;
- }
-
- /**
- * Retrieves the illegal charset name
- */
- public String getCharsetName ()
- {
- return charsetName;
- }
-}
diff --git a/libjava/classpath/java/nio/charset/package.html b/libjava/classpath/java/nio/charset/package.html
deleted file mode 100644
index acc7c02..0000000
--- a/libjava/classpath/java/nio/charset/package.html
+++ /dev/null
@@ -1,47 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
-<!-- package.html - describes classes in java.nio.charset package.
- Copyright (C) 2002 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. -->
-
-<html>
-<head><title>GNU Classpath - java.nio.charset</title></head>
-
-<body>
-<p>Classes to manipulate, encode and decode different character sets from
-and to bytes.</p>
-
-</body>
-</html>
diff --git a/libjava/classpath/java/nio/charset/spi/CharsetProvider.java b/libjava/classpath/java/nio/charset/spi/CharsetProvider.java
deleted file mode 100644
index 03653f8..0000000
--- a/libjava/classpath/java/nio/charset/spi/CharsetProvider.java
+++ /dev/null
@@ -1,95 +0,0 @@
-/* CharsetProvider.java -- charset service provider interface
- Copyright (C) 2002, 2005, 2006 Free Software Foundation
-
-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. */
-
-package java.nio.charset.spi;
-
-import java.nio.charset.Charset;
-import java.util.Iterator;
-
-
-/**
- * This class allows an implementor to provide additional character sets. The
- * subclass must have a nullary constructor, and be attached to charset
- * implementation classes. These extensions are loaded via the context class
- * loader. To provide the charset extension, all files named
- * <code>META-INF/services/java.nio.charset.spi.CharsetProvider</code> are
- * read from the classpath. Each one should be a UTF-8 encoded list of
- * fully-qualified names of concrete subclasses of this class; whitespace is
- * ignored, and '#' starts comments. Duplicates are ignored. The
- * implementations must be accessible to the classloader that requests them.
- *
- * @author Eric Blake (ebb9@email.byu.edu)
- * @see Charset
- * @since 1.4
- * @status updated to 1.4
- */
-public abstract class CharsetProvider
-{
- /**
- * Initialize a new charset provider. This performs a security check on
- * RuntimePermission("charsetProvider").
- *
- * @throws SecurityException if building a new set is not allowed
- */
- protected CharsetProvider()
- {
- // We only do the security check for custom providers, not for the
- // built in ones.
- SecurityManager s = System.getSecurityManager();
- if (s != null &&
- ! (this instanceof gnu.java.nio.charset.Provider
- || this instanceof gnu.java.nio.charset.iconv.IconvProvider))
- s.checkPermission(new RuntimePermission("charsetProvider"));
- }
-
- /**
- * Returns an iterator over the charsets defined by this provider.
- *
- * @return the iterator
- * @see Charset#availableCharsets()
- */
- public abstract Iterator<Charset> charsets();
-
- /**
- * Returns the named charset, by canonical name or alias.
- *
- * @param name the name of the character
- *
- * @return the charset, or null if not supported
- */
- public abstract Charset charsetForName(String name);
-} // class CharsetProvider
diff --git a/libjava/classpath/java/nio/charset/spi/package.html b/libjava/classpath/java/nio/charset/spi/package.html
deleted file mode 100644
index dd47a25..0000000
--- a/libjava/classpath/java/nio/charset/spi/package.html
+++ /dev/null
@@ -1,46 +0,0 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
-<!-- package.html - describes classes in java.nio.charset.spi package.
- Copyright (C) 2002 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. -->
-
-<html>
-<head><title>GNU Classpath - java.nio.charset.spi</title></head>
-
-<body>
-<p>Classes to provide new character sets.</p>
-
-</body>
-</html>