2002-08-02 19:57:46 +00:00
|
|
|
/*
|
|
|
|
* synergy -- mouse and keyboard sharing utility
|
|
|
|
* Copyright (C) 2002 Chris Schoeneman
|
|
|
|
*
|
|
|
|
* This package is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* found in the file COPYING that should have accompanied this file.
|
|
|
|
*
|
|
|
|
* This package 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.
|
|
|
|
*/
|
|
|
|
|
2001-10-06 14:13:28 +00:00
|
|
|
#ifndef XBASE_H
|
|
|
|
#define XBASE_H
|
|
|
|
|
|
|
|
#include "CString.h"
|
2002-06-01 19:26:11 +00:00
|
|
|
#include "stdpre.h"
|
2001-10-06 14:13:28 +00:00
|
|
|
#include <exception>
|
2002-06-01 19:26:11 +00:00
|
|
|
#include "stdpost.h"
|
2001-10-06 14:13:28 +00:00
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Exception base class
|
|
|
|
/*!
|
|
|
|
This is the base class of most exception types.
|
|
|
|
*/
|
2001-10-06 14:13:28 +00:00
|
|
|
class XBase : public std::exception {
|
2002-04-29 14:40:01 +00:00
|
|
|
public:
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Use getWhat() as the result of what()
|
2001-10-06 14:13:28 +00:00
|
|
|
XBase();
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Use \c msg as the result of what()
|
2001-10-06 14:13:28 +00:00
|
|
|
XBase(const CString& msg);
|
|
|
|
virtual ~XBase();
|
|
|
|
|
|
|
|
// std::exception overrides
|
|
|
|
virtual const char* what() const;
|
|
|
|
|
2002-04-29 14:40:01 +00:00
|
|
|
protected:
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Get a human readable string describing the exception
|
2001-10-06 14:13:28 +00:00
|
|
|
virtual CString getWhat() const throw() = 0;
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Format a string
|
|
|
|
/*!
|
|
|
|
Looks up a message format using \c id, using \c defaultFormat if
|
|
|
|
no format can be found, then replaces positional parameters in
|
|
|
|
the format string and returns the result.
|
|
|
|
*/
|
2001-10-06 14:13:28 +00:00
|
|
|
virtual CString format(const char* id,
|
2002-06-10 22:06:45 +00:00
|
|
|
const char* defaultFormat, ...) const throw();
|
2001-10-06 14:13:28 +00:00
|
|
|
|
2002-04-29 14:40:01 +00:00
|
|
|
private:
|
2001-10-06 14:13:28 +00:00
|
|
|
mutable CString m_what;
|
|
|
|
};
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Mix-in for handling \c errno
|
|
|
|
/*!
|
|
|
|
This mix-in class for exception classes provides storage and query of
|
|
|
|
\c errno.
|
|
|
|
*/
|
2001-10-06 14:13:28 +00:00
|
|
|
class MXErrno {
|
2002-04-29 14:40:01 +00:00
|
|
|
public:
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Save \c errno as the error code
|
2001-10-06 14:13:28 +00:00
|
|
|
MXErrno();
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Save \c err as the error code
|
|
|
|
MXErrno(int err);
|
2001-10-06 14:13:28 +00:00
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! @name accessors
|
|
|
|
//@{
|
2001-10-06 14:13:28 +00:00
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Get the error code
|
2001-10-06 14:13:28 +00:00
|
|
|
int getErrno() const;
|
2002-07-26 18:28:18 +00:00
|
|
|
|
|
|
|
//! Get the human readable string for the error code
|
2001-10-06 14:13:28 +00:00
|
|
|
const char* getErrstr() const;
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//@}
|
|
|
|
|
2002-04-29 14:40:01 +00:00
|
|
|
private:
|
2001-10-06 14:13:28 +00:00
|
|
|
int m_errno;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|