You've already forked libopenshot
mirror of
https://github.com/OpenShot/libopenshot.git
synced 2026-03-02 08:53:52 -08:00
BaseException is a python standard library exception class, so it's not a great idea to redefine that name in our bindings. Renamed to ExceptionBase, which is more in keeping with our class naming system anyway.
402 lines
11 KiB
C++
402 lines
11 KiB
C++
/**
|
|
* @file
|
|
* @brief Header file for all Exception classes
|
|
* @author Jonathan Thomas <jonathan@openshot.org>
|
|
*
|
|
* @ref License
|
|
*/
|
|
|
|
/* LICENSE
|
|
*
|
|
* Copyright (c) 2008-2019 OpenShot Studios, LLC
|
|
* <http://www.openshotstudios.com/>. This file is part of
|
|
* OpenShot Library (libopenshot), an open-source project dedicated to
|
|
* delivering high quality video editing and animation solutions to the
|
|
* world. For more information visit <http://www.openshot.org/>.
|
|
*
|
|
* OpenShot Library (libopenshot) is free software: you can redistribute it
|
|
* and/or modify it under the terms of the GNU Lesser General Public License
|
|
* as published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* OpenShot Library (libopenshot) 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with OpenShot Library. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef OPENSHOT_EXCEPTIONS_H
|
|
#define OPENSHOT_EXCEPTIONS_H
|
|
|
|
#include <string>
|
|
|
|
namespace openshot {
|
|
|
|
/**
|
|
* @brief Base exception class with a custom message variable.
|
|
*
|
|
* A std::exception-derived exception class with custom message.
|
|
* All OpenShot exception classes inherit from this class.
|
|
*/
|
|
class ExceptionBase : public std::exception //: public exception
|
|
{
|
|
protected:
|
|
std::string m_message;
|
|
public:
|
|
ExceptionBase(std::string message) : m_message(message) { }
|
|
virtual ~ExceptionBase() noexcept {}
|
|
virtual const char* what() const noexcept {
|
|
// return custom message
|
|
return m_message.c_str();
|
|
}
|
|
};
|
|
|
|
/// Exception when a required chunk is missing
|
|
class ChunkNotFound : public ExceptionBase
|
|
{
|
|
public:
|
|
int64_t frame_number;
|
|
int64_t chunk_number;
|
|
int64_t chunk_frame;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param frame_number The frame number being processed
|
|
* @param chunk_number The chunk requested
|
|
* @param chunk_frame The chunk frame
|
|
*/
|
|
ChunkNotFound(std::string message, int64_t frame_number, int64_t chunk_number, int64_t chunk_frame)
|
|
: ExceptionBase(message), frame_number(frame_number), chunk_number(chunk_number), chunk_frame(chunk_frame) { }
|
|
virtual ~ChunkNotFound() noexcept {}
|
|
};
|
|
|
|
|
|
/// Exception when accessing a blackmagic decklink card
|
|
class DecklinkError : public ExceptionBase
|
|
{
|
|
public:
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
*/
|
|
DecklinkError(std::string message)
|
|
: ExceptionBase(message) { }
|
|
virtual ~DecklinkError() noexcept {}
|
|
};
|
|
|
|
/// Exception when decoding audio packet
|
|
class ErrorDecodingAudio : public ExceptionBase
|
|
{
|
|
public:
|
|
int64_t frame_number;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param frame_number The frame number being processed
|
|
*/
|
|
ErrorDecodingAudio(std::string message, int64_t frame_number)
|
|
: ExceptionBase(message), frame_number(frame_number) { }
|
|
virtual ~ErrorDecodingAudio() noexcept {}
|
|
};
|
|
|
|
/// Exception when encoding audio packet
|
|
class ErrorEncodingAudio : public ExceptionBase
|
|
{
|
|
public:
|
|
int64_t frame_number;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param frame_number The frame number being processed
|
|
*/
|
|
ErrorEncodingAudio(std::string message, int64_t frame_number)
|
|
: ExceptionBase(message), frame_number(frame_number) { }
|
|
virtual ~ErrorEncodingAudio() noexcept {}
|
|
};
|
|
|
|
/// Exception when encoding audio packet
|
|
class ErrorEncodingVideo : public ExceptionBase
|
|
{
|
|
public:
|
|
int64_t frame_number;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param frame_number The frame number being processed
|
|
*/
|
|
ErrorEncodingVideo(std::string message, int64_t frame_number)
|
|
: ExceptionBase(message), frame_number(frame_number) { }
|
|
virtual ~ErrorEncodingVideo() noexcept {}
|
|
};
|
|
|
|
/// Exception when an invalid # of audio channels are detected
|
|
class InvalidChannels : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidChannels(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidChannels() noexcept {}
|
|
};
|
|
|
|
/// Exception when no valid codec is found for a file
|
|
class InvalidCodec : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidCodec(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidCodec() noexcept {}
|
|
};
|
|
|
|
/// Exception for files that can not be found or opened
|
|
class InvalidFile : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path The input file being processed
|
|
*/
|
|
InvalidFile(std::string message, std::string file_path)
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidFile() noexcept {}
|
|
};
|
|
|
|
/// Exception when no valid format is found for a file
|
|
class InvalidFormat : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidFormat(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidFormat() noexcept {}
|
|
};
|
|
|
|
/// Exception for invalid JSON
|
|
class InvalidJSON : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidJSON(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidJSON() noexcept {}
|
|
};
|
|
|
|
/// Exception when invalid encoding options are used
|
|
class InvalidOptions : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidOptions(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidOptions() noexcept {}
|
|
};
|
|
|
|
/// Exception when invalid sample rate is detected during encoding
|
|
class InvalidSampleRate : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
InvalidSampleRate(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~InvalidSampleRate() noexcept {}
|
|
};
|
|
|
|
/// Exception for missing JSON Change key
|
|
class InvalidJSONKey : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string json;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param json The json data being processed
|
|
*/
|
|
InvalidJSONKey(std::string message, std::string json)
|
|
: ExceptionBase(message), json(json) { }
|
|
virtual ~InvalidJSONKey() noexcept {}
|
|
};
|
|
|
|
/// Exception when no streams are found in the file
|
|
class NoStreamsFound : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
NoStreamsFound(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~NoStreamsFound() noexcept {}
|
|
};
|
|
|
|
/// Exception for frames that are out of bounds.
|
|
class OutOfBoundsFrame : public ExceptionBase
|
|
{
|
|
public:
|
|
int64_t FrameRequested;
|
|
int64_t MaxFrames;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param frame_requested The out-of-bounds frame number requested
|
|
* @param max_frames The maximum available frame number
|
|
*/
|
|
OutOfBoundsFrame(std::string message, int64_t frame_requested, int64_t max_frames)
|
|
: ExceptionBase(message), FrameRequested(frame_requested), MaxFrames(max_frames) { }
|
|
virtual ~OutOfBoundsFrame() noexcept {}
|
|
};
|
|
|
|
/// Exception for an out of bounds key-frame point.
|
|
class OutOfBoundsPoint : public ExceptionBase
|
|
{
|
|
public:
|
|
int PointRequested;
|
|
int MaxPoints;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param point_requested The out-of-bounds point requested
|
|
* @param max_points The maximum available point value
|
|
*/
|
|
OutOfBoundsPoint(std::string message, int point_requested, int max_points)
|
|
: ExceptionBase(message), PointRequested(point_requested), MaxPoints(max_points) { }
|
|
virtual ~OutOfBoundsPoint() noexcept {}
|
|
};
|
|
|
|
/// Exception when memory could not be allocated
|
|
class OutOfMemory : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
OutOfMemory(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~OutOfMemory() noexcept {}
|
|
};
|
|
|
|
/// Exception when a reader is closed, and a frame is requested
|
|
class ReaderClosed : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
ReaderClosed(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~ReaderClosed() noexcept {}
|
|
};
|
|
|
|
/// Exception when resample fails
|
|
class ResampleError : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
ResampleError(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~ResampleError() noexcept {}
|
|
};
|
|
|
|
/// Exception when too many seek attempts happen
|
|
class TooManySeeks : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The input file being processed
|
|
*/
|
|
TooManySeeks(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~TooManySeeks() noexcept {}
|
|
};
|
|
|
|
/// Exception when a writer is closed, and a frame is requested
|
|
class WriterClosed : public ExceptionBase
|
|
{
|
|
public:
|
|
std::string file_path;
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* @param message A message to accompany the exception
|
|
* @param file_path (optional) The output file being written
|
|
*/
|
|
WriterClosed(std::string message, std::string file_path="")
|
|
: ExceptionBase(message), file_path(file_path) { }
|
|
virtual ~WriterClosed() noexcept {}
|
|
};
|
|
}
|
|
|
|
#endif
|