From 07b78716af6a9d7c9fd1e94d9baf94a52c873947 Mon Sep 17 00:00:00 2001
From: Andrew Haley <aph@redhat.com>
Date: Fri, 30 Sep 2016 16:24:48 +0000
Subject: 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
---
 .../classpath/javax/sound/sampled/AudioSystem.java | 756 ---------------------
 1 file changed, 756 deletions(-)
 delete mode 100644 libjava/classpath/javax/sound/sampled/AudioSystem.java

(limited to 'libjava/classpath/javax/sound/sampled/AudioSystem.java')

diff --git a/libjava/classpath/javax/sound/sampled/AudioSystem.java b/libjava/classpath/javax/sound/sampled/AudioSystem.java
deleted file mode 100644
index 5999521..0000000
--- a/libjava/classpath/javax/sound/sampled/AudioSystem.java
+++ /dev/null
@@ -1,756 +0,0 @@
-/* Main interface to audio system
-   Copyright (C) 2005, 2012 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 javax.sound.sampled;
-
-import gnu.classpath.ServiceFactory;
-
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.OutputStream;
-import java.net.URL;
-import java.util.HashSet;
-import java.util.Iterator;
-
-import javax.sound.sampled.spi.AudioFileReader;
-import javax.sound.sampled.spi.AudioFileWriter;
-import javax.sound.sampled.spi.FormatConversionProvider;
-import javax.sound.sampled.spi.MixerProvider;
-
-/**
- * This clas is the primary interface to the audio system.  It contains
- * a number of static methods which can be used to access this package's
- * functionality.
- *
- * @since 1.3
- */
-public class AudioSystem
-{
-  /**
-   * A constant which can be passed to a number of methods in this package,
-   * to indicate an unspecified value.
-   */
-  public static final int NOT_SPECIFIED = -1;
-
-  // This class is not instantiable.
-  private AudioSystem()
-  {
-  }
-
-  /**
-   * Return the file format of a given File.
-   * @param f the file to check
-   * @return the format of the file
-   * @throws UnsupportedAudioFileException if the file's format is not
-   * recognized
-   * @throws IOException if there is an I/O error reading the file
-   */
-  public static AudioFileFormat getAudioFileFormat(File f)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioFileFormat(f);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("file type not recognized");
-  }
-
-  /**
-   * Return the file format of a given input stream.
-   * @param is the input stream to check
-   * @return the format of the stream
-   * @throws UnsupportedAudioFileException if the stream's format is not
-   * recognized
-   * @throws IOException if there is an I/O error reading the stream
-   */
-  public static AudioFileFormat getAudioFileFormat(InputStream is)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioFileFormat(is);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("input stream type not recognized");
-  }
-
-  /**
-   * Return the file format of a given URL.
-   * @param url the URL to check
-   * @return the format of the URL
-   * @throws UnsupportedAudioFileException if the URL's format is not
-   * recognized
-   * @throws IOException if there is an I/O error reading the URL
-   */
-  public static AudioFileFormat getAudioFileFormat(URL url)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioFileFormat(url);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("URL type not recognized");
-  }
-
-  /**
-   * Return an array of all the supported AudioFileFormat types.
-   * @return an array of unique types
-   */
-  public static AudioFileFormat.Type[] getAudioFileTypes()
-  {
-    HashSet<AudioFileFormat.Type> result
-      = new HashSet<AudioFileFormat.Type>();
-    Iterator<AudioFileWriter> i = ServiceFactory.lookupProviders(AudioFileWriter.class);
-    while (i.hasNext())
-      {
-        AudioFileWriter writer = i.next();
-        AudioFileFormat.Type[] types = writer.getAudioFileTypes();
-        for (int j = 0; j < types.length; ++j)
-          result.add(types[j]);
-      }
-    return result.toArray(new AudioFileFormat.Type[result.size()]);
-  }
-
-  /**
-   * Return an array of all the supported AudioFileFormat types which match the
-   * given audio input stream
-   * @param ais the audio input stream
-   * @return an array of unique types
-   */
-  public static AudioFileFormat.Type[] getAudioFileTypes(AudioInputStream ais)
-  {
-    HashSet<AudioFileFormat.Type> result
-      = new HashSet<AudioFileFormat.Type>();
-    Iterator<AudioFileWriter> i = ServiceFactory.lookupProviders(AudioFileWriter.class);
-    while (i.hasNext())
-      {
-        AudioFileWriter writer = i.next();
-        AudioFileFormat.Type[] types = writer.getAudioFileTypes(ais);
-        for (int j = 0; j < types.length; ++j)
-          result.add(types[j]);
-      }
-    return result.toArray(new AudioFileFormat.Type[result.size()]);
-  }
-
-  /**
-   * Given an audio input stream, this will try to create a new audio input
-   * stream whose encoding matches the given target encoding.  If no provider
-   * offers this conversion, an exception is thrown.
-   * @param targ the target encoding
-   * @param ais the original audio stream
-   * @return a new audio stream
-   * @throws IllegalArgumentException if the conversion cannot be made
-   */
-  public static AudioInputStream getAudioInputStream(AudioFormat.Encoding targ,
-                                                     AudioInputStream ais)
-  {
-    Iterator<FormatConversionProvider> i =
-      ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        if (! prov.isConversionSupported(targ, ais.getFormat()))
-          continue;
-        return prov.getAudioInputStream(targ, ais);
-      }
-    throw new IllegalArgumentException("encoding not supported for stream");
- }
-
-  /**
-   * Given an audio input stream, this will try to create a new audio input
-   * stream whose format matches the given target format.  If no provider
-   * offers this conversion, an exception is thrown.
-   * @param targ the target format
-   * @param ais the original audio stream
-   * @return a new audio stream
-   * @throws IllegalArgumentException if the conversion cannot be made
-   */
-  public static AudioInputStream getAudioInputStream(AudioFormat targ,
-                                                     AudioInputStream ais)
-  {
-    Iterator<FormatConversionProvider> i =
-      ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        if (! prov.isConversionSupported(targ, ais.getFormat()))
-          continue;
-        return prov.getAudioInputStream(targ, ais);
-      }
-    throw new IllegalArgumentException("format not supported for stream");
-   }
-
-  /**
-   * Return an audio input stream for the file.
-   * @param f the file to read
-   * @return an audio input stream for the file
-   * @throws UnsupportedAudioFileException if the file's audio format is not
-   * recognized
-   * @throws IOException if there is an error while reading the file
-   */
-  public static AudioInputStream getAudioInputStream(File f)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioInputStream(f);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("file type not recognized");
-  }
-
-  /**
-   * Return an audio input stream given an input stream.
-   * @param is the input stream
-   * @return an audio input stream
-   * @throws UnsupportedAudioFileException if the input stream's audio format
-   * is not supported by any of the installed providers
-   * @throws IOException if there is an error while reading the input stream
-   */
-  public static AudioInputStream getAudioInputStream(InputStream is)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioInputStream(is);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("input stream type not recognized");
-  }
-
-  /**
-   * Return an audio input stream for the given URL.
-   * @param url the URL
-   * @return an audio input stream
-   * @throws UnsupportedAudioFileException if the URL's audio format is not
-   * supported by any of the installed providers
-   * @throws IOException if there is an error while reading the URL
-   */
-  public static AudioInputStream getAudioInputStream(URL url)
-    throws UnsupportedAudioFileException, IOException
-  {
-    Iterator<AudioFileReader> i = ServiceFactory.lookupProviders(AudioFileReader.class);
-    while (i.hasNext())
-      {
-        AudioFileReader reader = i.next();
-        try
-          {
-            return reader.getAudioInputStream(url);
-          }
-        catch (UnsupportedAudioFileException _)
-          {
-            // Try the next provider.
-          }
-      }
-    throw new UnsupportedAudioFileException("URL type not recognized");
-  }
-
-  /**
-   * Return a new clip which can be used for playing back an audio stream.
-   * @throws LineUnavailableException if a clip is not available for some
-   * reason
-   * @throws SecurityException if a clip cannot be made for security reasons
-   * @since 1.5
-   */
-  public static Clip getClip()
-    throws LineUnavailableException
-  {
-    Mixer.Info[] infos = getMixerInfo();
-    for (int i = 0; i < infos.length; ++i)
-      {
-        Mixer mix = getMixer(infos[i]);
-        Line[] lines = mix.getSourceLines();
-        for (int j = 0; j < lines.length; ++j)
-          {
-            if (lines[j] instanceof Clip)
-              return (Clip) lines[j];
-          }
-      }
-    throw new LineUnavailableException("no Clip available");
-  }
-
-  /**
-   * Return a new clip which can be used for playing back an audio stream.
-   * The clip is obtained from the indicated mixer.
-   * @param info the mixer to use
-   * @throws LineUnavailableException if a clip is not available for some
-   * reason
-   * @throws SecurityException if a clip cannot be made for security reasons
-   * @since 1.5
-   */
-  public static Clip getClip(Mixer.Info info)
-    throws LineUnavailableException
-  {
-    Mixer mix = getMixer(info);
-    Line[] lines = mix.getSourceLines();
-    for (int j = 0; j < lines.length; ++j)
-      {
-        if (lines[j] instanceof Clip)
-          return (Clip) lines[j];
-      }
-    throw new LineUnavailableException("no Clip available");
-  }
-
-  /**
-   * Return a line matching the provided description.  All the providers
-   * on the system are searched for a matching line.
-   * @param info description of the line
-   * @return the matching line
-   * @throws LineUnavailableException if no provider supplies a matching line
-   */
-  public static Line getLine(Line.Info info) throws LineUnavailableException
-  {
-    Mixer.Info[] infos = getMixerInfo();
-    for (int i = 0; i < infos.length; ++i)
-      {
-        Mixer mix = getMixer(infos[i]);
-        try
-        {
-          return mix.getLine(info);
-        }
-        catch (LineUnavailableException _)
-        {
-          // Try the next provider.
-        }
-      }
-    throw new LineUnavailableException("no Clip available");
-  }
-
-  /**
-   * Return a mixer matching the provided description.  All the providers
-   * on the system are searched for a matching mixer.
-   * @param info description of the mixer
-   * @return the matching mixer
-   * @throws IllegalArgumentException if no provider supplies a matching mixer
-   */
-  public static Mixer getMixer(Mixer.Info info)
-  {
-    Iterator<MixerProvider> i = ServiceFactory.lookupProviders(MixerProvider.class);
-    while (i.hasNext())
-      {
-        MixerProvider prov = i.next();
-        if (prov.isMixerSupported(info))
-          return prov.getMixer(info);
-      }
-    throw new IllegalArgumentException("mixer not found");
-  }
-
-  /**
-   * Return an array of descriptions of all the mixers provided on the system.
-   */
-  public static Mixer.Info[] getMixerInfo()
-  {
-    HashSet<Mixer.Info> result = new HashSet<Mixer.Info>();
-    Iterator<MixerProvider> i = ServiceFactory.lookupProviders(MixerProvider.class);
-    while (i.hasNext())
-      {
-        MixerProvider prov = i.next();
-        Mixer.Info[] is = prov.getMixerInfo();
-        for (int j = 0; j < is.length; ++j)
-          result.add(is[j]);
-      }
-    return result.toArray(new Mixer.Info[result.size()]);
-  }
-
-  /**
-   * Return a source data line matching the given audio format.
-   * @param fmt the audio format
-   * @throws LineUnavailableException if no source data line matching
-   * this format is available
-   * @since 1.5
-   */
-  public static SourceDataLine getSourceDataLine(AudioFormat fmt)
-    throws LineUnavailableException
-  {
-    DataLine.Info info = new DataLine.Info(SourceDataLine.class, fmt);
-    Mixer.Info[] mixers = getMixerInfo();
-    for (int i = 0; i < mixers.length; ++i)
-      {
-        Mixer mix = getMixer(mixers[i]);
-        if (mix.isLineSupported(info))
-          return (SourceDataLine) mix.getLine(info);
-      }
-    throw new LineUnavailableException("source data line not found");
-  }
-
-  /**
-   * Return a target data line matching the given audio format.
-   * @param fmt the audio format
-   * @throws LineUnavailableException if no target data line matching
-   * this format is available
-   * @since 1.5
-   */
-  public static SourceDataLine getSourceDataLine(AudioFormat fmt,
-                                                 Mixer.Info mixer)
-    throws LineUnavailableException
-  {
-    DataLine.Info info = new DataLine.Info(SourceDataLine.class, fmt);
-    Mixer mix = getMixer(mixer);
-    if (mix.isLineSupported(info))
-      return (SourceDataLine) mix.getLine(info);
-    throw new LineUnavailableException("source data line not found");
-  }
-
-  /**
-   * Return an array of descriptions of all the source lines matching
-   * the given line description.
-   * @param info description of the lines to match
-   */
-  public static Line.Info[] getSourceLineInfo(Line.Info info)
-  {
-    HashSet<Line.Info> result = new HashSet<Line.Info>();
-    Mixer.Info[] infos = getMixerInfo();
-    for (int i = 0; i < infos.length; ++i)
-      {
-        Mixer mix = getMixer(infos[i]);
-        Line.Info[] srcs = mix.getSourceLineInfo(info);
-        for (int j = 0; j < srcs.length; ++j)
-          result.add(srcs[j]);
-      }
-    return result.toArray(new Line.Info[result.size()]);
-  }
-
-  /**
-   * Find and return a target data line matching the given audio format.
-   * @param fmt the format to match
-   * @throws LineUnavailableException if no matching line was found
-   * @since 1.5
-   */
-  public static TargetDataLine getTargetDataLine(AudioFormat fmt)
-    throws LineUnavailableException
-  {
-    DataLine.Info info = new DataLine.Info(TargetDataLine.class, fmt);
-    Mixer.Info[] mixers = getMixerInfo();
-    for (int i = 0; i < mixers.length; ++i)
-      {
-        Mixer mix = getMixer(mixers[i]);
-        if (mix.isLineSupported(info))
-          return (TargetDataLine) mix.getLine(info);
-      }
-    throw new LineUnavailableException("target data line not found");
-  }
-
-  /**
-   * Return a target data line matching the given audio format and
-   * mixer.
-   * @param fmt the audio format
-   * @param mixer the mixer description
-   * @return a target data line
-   * @throws LineUnavailableException if no matching target data line was
-   * found
-   * @since 1.5
-   */
-  public static TargetDataLine getTargetDataLine(AudioFormat fmt,
-                                                 Mixer.Info mixer)
-    throws LineUnavailableException
-  {
-    DataLine.Info info = new DataLine.Info(TargetDataLine.class, fmt);
-    Mixer mix = getMixer(mixer);
-    if (mix.isLineSupported(info))
-      return (TargetDataLine) mix.getLine(info);
-    throw new LineUnavailableException("target data line not found");
-  }
-
-  /**
-   * Given a source encoding, return an array of all target encodings to which
-   * data in this form can be converted.
-   * @param source the source encoding
-   */
-  public static AudioFormat.Encoding[] getTargetEncodings(AudioFormat.Encoding source)
-  {
-    HashSet<AudioFormat.Encoding> result
-      = new HashSet<AudioFormat.Encoding>();
-    Iterator<FormatConversionProvider> i =
-      ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        if (! prov.isSourceEncodingSupported(source))
-          continue;
-        AudioFormat.Encoding[] es = prov.getTargetEncodings();
-        for (int j = 0; j < es.length; ++j)
-          result.add(es[j]);
-      }
-    return result.toArray(new AudioFormat.Encoding[result.size()]);
-  }
-
-  /**
-   * Given a source format, return an array of all the target encodings to
-   * which data in this format can be converted.
-   * @param source the source format
-   */
-  public static AudioFormat.Encoding[] getTargetEncodings(AudioFormat source)
-  {
-    HashSet<AudioFormat.Encoding> result
-      = new HashSet<AudioFormat.Encoding>();
-    Iterator<FormatConversionProvider> i =
-      ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        AudioFormat.Encoding[] es = prov.getTargetEncodings(source);
-        for (int j = 0; j < es.length; ++j)
-          result.add(es[j]);
-      }
-    return result.toArray(new AudioFormat.Encoding[result.size()]);
-  }
-
-  /**
-   * Given a target encoding and a source audio format, return an array of all
-   * matching audio formats to which data in this source format can be converted.
-   * @param encoding the target encoding
-   * @param sourceFmt the source format
-   */
-  public static AudioFormat[] getTargetFormats(AudioFormat.Encoding encoding,
-                                               AudioFormat sourceFmt)
-  {
-    HashSet<AudioFormat> result = new HashSet<AudioFormat>();
-    Iterator<FormatConversionProvider> i =
-      ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        AudioFormat[] es = prov.getTargetFormats(encoding, sourceFmt);
-        for (int j = 0; j < es.length; ++j)
-          result.add(es[j]);
-      }
-    return result.toArray(new AudioFormat[result.size()]);
-  }
-
-  /**
-   * Given a line description, return an array of descriptions of all
-   * the matching target lines.
-   * @param info the line description
-   */
-  public static Line.Info[] getTargetLineInfo(Line.Info info)
-  {
-    HashSet<Line.Info> result = new HashSet<Line.Info>();
-    Mixer.Info[] infos = getMixerInfo();
-    for (int i = 0; i < infos.length; ++i)
-      {
-        Mixer mix = getMixer(infos[i]);
-        Line.Info[] targs = mix.getTargetLineInfo(info);
-        for (int j = 0; j < targs.length; ++j)
-          result.add(targs[j]);
-      }
-    return result.toArray(new Line.Info[result.size()]);
-  }
-
-  /**
-   * Return true if the currently installed providers are able to
-   * convert data from the given source format to the given target encoding.
-   * @param targ the target encoding
-   * @param source the source format
-   */
-  public static boolean isConversionSupported(AudioFormat.Encoding targ,
-                                              AudioFormat source)
-  {
-    Iterator<FormatConversionProvider> i
-      = ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        if (prov.isConversionSupported(targ, source))
-          return true;
-      }
-    return false;
-  }
-
-  /**
-   * Return true if the currently installed providers are able to convert
-   * the given source format to the given target format.
-   * @param targ the target format
-   * @param source the source format
-   */
-  public static boolean isConversionSupported(AudioFormat targ,
-                                              AudioFormat source)
-  {
-    Iterator<FormatConversionProvider> i
-      = ServiceFactory.lookupProviders(FormatConversionProvider.class);
-    while (i.hasNext())
-      {
-        FormatConversionProvider prov = i.next();
-        if (prov.isConversionSupported(targ, source))
-          return true;
-      }
-    return false;
-  }
-
-  private static boolean isFileTypeSupported(AudioFileFormat.Type[] types,
-                                             AudioFileFormat.Type type)
-  {
-    for (int i = 0; i < types.length; ++i)
-      {
-        if (types[i].equals(type))
-          return true;
-      }
-    return false;
-  }
-
-  /**
-   * Return true if the given audio file format is supported by one of
-   * the providers installed on the system.
-   * @param type the audio file format type
-   */
-  public static boolean isFileTypeSupported(AudioFileFormat.Type type)
-  {
-    return isFileTypeSupported(getAudioFileTypes(), type);
-  }
-
-  /**
-   * Return true if the given audio file format is supported for the
-   * given audio input stream by one of the providers installed on the
-   * system.
-   * @param type the audio file format type
-   * @param ais the audio input stream
-   */
-  public static boolean isFileTypeSupported(AudioFileFormat.Type type,
-                                            AudioInputStream ais)
-  {
-    return isFileTypeSupported(getAudioFileTypes(ais), type);
-  }
-
-  /**
-   * Return true if some provider on the system supplies a line
-   * matching the argument.
-   * @param info the line to match
-   */
-  public static boolean isLineSupported(Line.Info info)
-  {
-    Mixer.Info[] infos = getMixerInfo();
-    for (int i = 0; i < infos.length; ++i)
-      {
-        if (getMixer(infos[i]).isLineSupported(info))
-          return true;
-      }
-    return false;
-  }
-
-  /**
-   * Write an audio input stream to the given file, using the specified
-   * audio file format.  All the providers installed on the system will
-   * be searched to find one that supports this operation.
-   * @param ais the audio input stream to write
-   * @param type the desired audio file format type
-   * @param out the file to write to
-   * @return the number of bytes written
-   * @throws IOException if an I/O error occurs while writing
-   * @throws IllegalArgumentException if the file type is not supported
-   */
-  public static int write(AudioInputStream ais, AudioFileFormat.Type type,
-                          File out)
-    throws IOException
-  {
-    Iterator<AudioFileWriter> i = ServiceFactory.lookupProviders(AudioFileWriter.class);
-    while (i.hasNext())
-      {
-        AudioFileWriter w = i.next();
-        if (w.isFileTypeSupported(type, ais))
-          return w.write(ais, type, out);
-      }
-    throw new IllegalArgumentException("file type not supported by system");
-  }
-
-  /**
-   * Write an audio input stream to the given output stream, using the
-   * specified audio file format.  All the providers installed on the
-   * system will be searched to find one that supports this operation.
-   * @param ais the audio input stream to write
-   * @param type the desired audio file format type
-   * @param os the output stream to write to
-   * @return the number of bytes written
-   * @throws IOException if an I/O error occurs while writing
-   * @throws IllegalArgumentException if the file type is not supported
-   */
-  public static int write(AudioInputStream ais, AudioFileFormat.Type type,
-                          OutputStream os)
-    throws IOException
-  {
-    Iterator<AudioFileWriter> i = ServiceFactory.lookupProviders(AudioFileWriter.class);
-    while (i.hasNext())
-      {
-        AudioFileWriter w = i.next();
-        if (w.isFileTypeSupported(type, ais))
-          return w.write(ais, type, os);
-      }
-    throw new IllegalArgumentException("file type not supported by system");
-  }
-}
-- 
cgit v1.1