audacia/src/import/ImportPlugin.h

185 lines
5.6 KiB
C++

/**********************************************************************
Audacity: A Digital Audio Editor
ImportPlugin.h
Joshua Haberman
Leland Lucius
*******************************************************************//**
\file ImportPlugin.h
\brief
The interface that all file import "plugins" (if you want to call
them that) must implement. Defines ImportFileHandle, ImportPlugin,
UnusableImportPlugin, ImportPluginList and UnusableImportPluginList.
Since this is part of libaudacity, it must not use any GUI parts
of wxWidgets.
*//****************************************************************//**
\class ImportFileHandle
\brief Base class for FlacImportFileHandle, LOFImportFileHandle,
MP3ImportFileHandle, OggImportFileHandle and PCMImportFileHandle.
Gives API for sound file import.
*//****************************************************************//**
\class ImportPlugin
\brief Base class for FlacImportPlugin, LOFImportPlugin,
MP3ImportPlugin, OggImportPlugin and PCMImportPlugin.
Gives API for sound file import.
*//****************************************************************//**
\class UnusableImportPlugin
\brief Used in place of a real plug in for plug ins that have not
been compiled or are not available in this version of Audacity. Has
enough information to identify the file extensions that would be used,
but little else.
*//*******************************************************************/
#ifndef __AUDACITY_IMPORTER__
#define __AUDACITY_IMPORTER__
#include "audacity/Types.h"
#include "../Internat.h"
#include "../MemoryX.h"
class AudacityProject;
class ProgressDialog;
enum class ProgressResult : unsigned;
class WaveTrackFactory;
class Track;
class Tags;
class ImportFileHandle;
class AUDACITY_DLL_API ImportPlugin /* not final */
{
public:
// Get unique string ID of this plugin, usually it corresponds
// to the underlying library, i.e. "libsndfile", "libflac", "libav"
// These MUST NOT change across Audacity versions (but NEW IDs can
// be added).
virtual wxString GetPluginStringID() = 0;
// Get a description of the file type this importer can import.
// Examples: "Ogg Vorbis", "MP3", "Uncompressed PCM"
virtual TranslatableString GetPluginFormatDescription() = 0;
// Get a list of extensions this plugin expects to be able to
// import. If a filename matches any of these extensions,
// this importer will get first dibs on importing it.
virtual FileExtensions GetSupportedExtensions();
bool SupportsExtension(const FileExtension &extension);
// Open the given file, returning true if it is in a recognized
// format, false otherwise. This puts the importer into the open
// state.
virtual std::unique_ptr<ImportFileHandle> Open(
const FilePath &Filename, AudacityProject*) = 0;
virtual ~ImportPlugin();
protected:
ImportPlugin(FileExtensions supportedExtensions);
const FileExtensions mExtensions;
};
class WaveTrack;
using TrackHolders = std::vector< std::vector< std::shared_ptr<WaveTrack> > >;
class AUDACITY_DLL_API ImportFileHandle /* not final */
{
public:
ImportFileHandle(const FilePath & filename);
virtual ~ImportFileHandle();
// The importer should call this to create the progress dialog and
// identify the filename being imported.
void CreateProgress();
// This is similar to GetPluginFormatDescription, but if possible the
// importer will return a more specific description of the
// specific file that is open.
virtual TranslatableString GetFileDescription() = 0;
// Return an estimate of how many bytes the file will occupy once
// imported. In principle this may exceed main memory, so don't use
// size_t.
using ByteCount = unsigned long long;
virtual ByteCount GetFileUncompressedBytes() = 0;
// do the actual import, creating whatever tracks are necessary with
// the WaveTrackFactory and calling the progress callback every iteration
// through the importing loop
// The given Tags structure may also be modified.
// In case of errors or exceptions, it is not necessary to leave outTracks
// or tags unmodified.
// If resulting outTracks is not empty,
// then each member of it must be a nonempty vector.
virtual ProgressResult Import(WaveTrackFactory *trackFactory, TrackHolders &outTracks,
Tags *tags) = 0;
// Return number of elements in stream list
virtual wxInt32 GetStreamCount() = 0;
// Return stream descriptions list
virtual const TranslatableStrings &GetStreamInfo() = 0;
// Set stream "import/don't import" flag
virtual void SetStreamUsage(wxInt32 StreamID, bool Use) = 0;
//! Choose appropriate format, which will not be narrower than the specified one
static sampleFormat ChooseFormat(sampleFormat effectiveFormat);
//! Build a wave track with appropriate format, which will not be narrower than the specified one
std::shared_ptr<WaveTrack> NewWaveTrack( WaveTrackFactory &trackFactory,
sampleFormat effectiveFormat, double rate);
protected:
FilePath mFilename;
std::unique_ptr<ProgressDialog> mProgress;
};
class UnusableImportPlugin
{
public:
UnusableImportPlugin(
const TranslatableString &formatName, FileExtensions extensions):
mFormatName(formatName),
mExtensions( std::move( extensions ) )
{
}
TranslatableString GetPluginFormatDescription()
{
return mFormatName;
}
bool SupportsExtension(const FileExtension &extension)
{
return mExtensions.Index(extension, false) != wxNOT_FOUND;
}
private:
TranslatableString mFormatName;
const FileExtensions mExtensions;
};
#endif