The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

87 lines
3.7KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library - "Jules' Utility Class Extensions"
  4. Copyright 2004-11 by Raw Material Software Ltd.
  5. ------------------------------------------------------------------------------
  6. JUCE can be redistributed and/or modified under the terms of the GNU General
  7. Public License (Version 2), as published by the Free Software Foundation.
  8. A copy of the license is included in the JUCE distribution, or can be found
  9. online at www.gnu.org/licenses.
  10. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  11. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  12. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  13. ------------------------------------------------------------------------------
  14. To release a closed-source product which uses JUCE, commercial licenses are
  15. available: visit www.rawmaterialsoftware.com/juce for more information.
  16. ==============================================================================
  17. */
  18. //==============================================================================
  19. /**
  20. Reads and Writes AIFF format audio files.
  21. @see AudioFormat
  22. */
  23. class JUCE_API AiffAudioFormat : public AudioFormat
  24. {
  25. public:
  26. //==============================================================================
  27. /** Creates an format object. */
  28. AiffAudioFormat();
  29. /** Destructor. */
  30. ~AiffAudioFormat();
  31. //==============================================================================
  32. /** Metadata property name used when reading a aiff file with a basc chunk. */
  33. static const char* const appleOneShot;
  34. /** Metadata property name used when reading a aiff file with a basc chunk. */
  35. static const char* const appleRootSet;
  36. /** Metadata property name used when reading a aiff file with a basc chunk. */
  37. static const char* const appleRootNote;
  38. /** Metadata property name used when reading a aiff file with a basc chunk. */
  39. static const char* const appleBeats;
  40. /** Metadata property name used when reading a aiff file with a basc chunk. */
  41. static const char* const appleDenominator;
  42. /** Metadata property name used when reading a aiff file with a basc chunk. */
  43. static const char* const appleNumerator;
  44. /** Metadata property name used when reading a aiff file with a basc chunk. */
  45. static const char* const appleTag;
  46. /** Metadata property name used when reading a aiff file with a basc chunk. */
  47. static const char* const appleKey;
  48. //==============================================================================
  49. Array<int> getPossibleSampleRates();
  50. Array<int> getPossibleBitDepths();
  51. bool canDoStereo();
  52. bool canDoMono();
  53. #if JUCE_MAC
  54. bool canHandleFile (const File& fileToTest);
  55. #endif
  56. //==============================================================================
  57. AudioFormatReader* createReaderFor (InputStream* sourceStream,
  58. bool deleteStreamIfOpeningFails);
  59. MemoryMappedAudioFormatReader* createMemoryMappedReader (const File&);
  60. AudioFormatWriter* createWriterFor (OutputStream* streamToWriteTo,
  61. double sampleRateToUse,
  62. unsigned int numberOfChannels,
  63. int bitsPerSample,
  64. const StringPairArray& metadataValues,
  65. int qualityOptionIndex);
  66. private:
  67. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(AiffAudioFormat)
  68. };