Exception.h
上传用户:sbftbdw
上传日期:2007-01-03
资源大小:379k
文件大小:2k
源码类别:

远程控制编程

开发平台:

Visual C++

  1. //  Copyright (C) 1997, 1998 Olivetti & Oracle Research Laboratory
  2. //
  3. //  This file is part of the VNC system.
  4. //
  5. //  The VNC system is free software; you can redistribute it and/or modify
  6. //  it under the terms of the GNU General Public License as published by
  7. //  the Free Software Foundation; either version 2 of the License, or
  8. //  (at your option) any later version.
  9. //
  10. //  This program is distributed in the hope that it will be useful,
  11. //  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13. //  GNU General Public License for more details.
  14. //
  15. //  You should have received a copy of the GNU General Public License
  16. //  along with this program; if not, write to the Free Software
  17. //  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,
  18. //  USA.
  19. //
  20. // If the source code for the VNC system is not available from the place 
  21. // whence you received this file, check http://www.orl.co.uk/vnc or contact
  22. // the authors on vnc@orl.co.uk for information on obtaining it.
  23. #pragma once
  24. // Exceptions used in VNCviewer
  25. class Exception  
  26. {
  27. public:
  28. Exception(const char *info = NULL);
  29. virtual void Report();
  30. virtual ~Exception();
  31. char *m_info;
  32. };
  33. // This indicates something that the catcher should close 
  34. // the connection quietly.
  35. // Report() will display a TRACE message
  36. class QuietException : public Exception {
  37. public:
  38. QuietException(const char *info = NULL);
  39. virtual void Report();
  40. virtual ~QuietException();
  41. };
  42. // This indicates something the user should be told about.
  43. // In situations of ambiguity, the 'close' parameter can be used
  44. // to specify whether or not the connection is closed as a result.
  45. // In general it will be.
  46. // Report() will display a message box
  47. class WarningException : public Exception {
  48. public:
  49. WarningException(const char *info = NULL, bool close = true);
  50. virtual void Report();
  51. virtual ~WarningException();
  52. bool m_close;
  53. };
  54. // This is serious stuff - similar to an assert - we may not use?
  55. // Report will display an important message box. Connection definitely
  56. // closed.
  57. class ErrorException : public Exception {
  58. public:
  59. ErrorException(const char *info = NULL);
  60. virtual void Report();
  61. virtual ~ErrorException();
  62. };