1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
/*
* Copyright (C) 2005-2013 Team XBMC
* http://xbmc.org
*
* This Program 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.
*
* This Program 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 XBMC; see the file COPYING. If not, see
* <http://www.gnu.org/licenses/>.
*
*/
#pragma once
#include "utils/log.h"
#include "commons/Exception.h"
#ifndef SWIG
namespace XBMCAddon
{
XBMCCOMMONS_STANDARD_EXCEPTION(WrongTypeException);
/**
* UnimplementedException Can be used in places like the
* Control hierarchy where the
* requirements of dynamic language usage force us to add
* unimplmenented methods to a class hierarchy. See the
* detailed explanation on the class Control for more.
*/
class UnimplementedException : public XbmcCommons::Exception
{
public:
inline UnimplementedException(const UnimplementedException& other) : Exception(other) { }
inline UnimplementedException(const char* classname, const char* methodname) :
Exception("UnimplementedException")
{ SetMessage("Unimplemented method: %s::%s(...)", classname, methodname); }
};
/**
* This is what callback exceptions from the scripting language
* are translated to.
*/
class UnhandledException : public XbmcCommons::Exception
{
public:
inline UnhandledException(const UnhandledException& other) : Exception(other) { }
inline UnhandledException(const char* _message,...) : Exception("UnhandledException") { XBMCCOMMONS_COPYVARARGS(_message); }
};
}
#endif
/**
* These macros allow the easy declaration (and definition) of parent
* class virtual methods that are not implemented until the child class.
* This is to support the idosyncracies of dynamically typed scripting
* languages. See the comment in AddonControl.h for more details.
*/
#define THROW_UNIMP(classname) throw UnimplementedException(classname, __FUNCTION__)
|