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 67 68 69 70 71 72 73 74 75 76 77
|
/* Copyright 2012 Geehalel (geehalel AT gmail DOT com) */
/* This file is part of the Skywatcher Protocol INDI driver.
The Skywatcher Protocol INDI driver 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 3 of the License, or
(at your option) any later version.
The Skywatcher Protocol INDI driver 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 the Skywatcher Protocol INDI driver. If not, see <http://www.gnu.org/licenses/>.
*/
#include "eqmoderror.h"
#include "eqmodbase.h"
EQModError::EQModError(Severity sev, const char *msg, ...)
{
if (msg)
{
va_list ap;
va_start(ap, msg);
vsnprintf(message, ERROR_MSG_LENGTH, msg, ap);
va_end(ap);
}
else
message[0] = '\0';
severity = sev;
}
const char *EQModError::severityString()
{
switch (severity)
{
case EQModError::ErrInvalidCmd:
return ("Invalid command");
case EQModError::ErrCmdFailed:
return ("Command failed");
case EQModError::ErrInvalidParameter:
return ("Invalid parameter");
case EQModError::ErrDisconnect:
return ("Communication failed");
default:
return ("Unknown severity");
}
}
bool EQModError::DefaultHandleException(EQMod *device)
{
switch (severity)
{
case EQModError::ErrInvalidCmd:
case EQModError::ErrCmdFailed:
case EQModError::ErrInvalidParameter:
DEBUGFDEVICE(device->getDeviceName(), INDI::Logger::DBG_WARNING, "Warning: %s -> %s", severityString(),
message);
return true;
case EQModError::ErrDisconnect:
DEBUGFDEVICE(device->getDeviceName(), INDI::Logger::DBG_ERROR, "Error: %s -> %s", severityString(),
message);
//device->Disconnect();
device->abnormalDisconnect();
return false;
default:
DEBUGFDEVICE(device->getDeviceName(), INDI::Logger::DBG_ERROR, "Unhandled exception: %s -> %s",
severityString(), message);
//device->Disconnect();
device->abnormalDisconnect();
return false;
//break;
}
}
|