view Core/OrthancException.cpp @ 121:a7e98bbeaf48 Orthanc-0.2.2

close
author Sebastien Jodogne <s.jodogne@gmail.com>
date Mon, 29 Apr 2013 12:54:48 +0200
parents c996319e90bc
children fe180eae201d
line wrap: on
line source

/**
 * Orthanc - A Lightweight, RESTful DICOM Store
 * Copyright (C) 2012 Medical Physics Department, CHU of Liege,
 * Belgium
 *
 * 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 3 of the
 * License, 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 this program. If not, see <http://www.gnu.org/licenses/>.
 **/


#include "OrthancException.h"

namespace Orthanc
{
  const char* OrthancException::What() const
  {
    if (error_ == ErrorCode_Custom)
    {
      return custom_.c_str();
    }
    else
    {
      return GetDescription(error_);
    }
  }


  const char* OrthancException::GetDescription(ErrorCode error)
  {
    switch (error)
    {
    case ErrorCode_Success:
      return "Success";

    case ErrorCode_ParameterOutOfRange:
      return "Parameter out of range";

    case ErrorCode_NotImplemented:
      return "Not implemented yet";

    case ErrorCode_InternalError:
      return "Internal error";

    case ErrorCode_NotEnoughMemory:
      return "Not enough memory";

    case ErrorCode_UriSyntax:
      return "Badly formatted URI";

    case ErrorCode_BadParameterType:
      return "Bad type for a parameter";

    case ErrorCode_InexistentFile:
      return "Inexistent file";

    case ErrorCode_BadFileFormat:
      return "Bad file format";

    case ErrorCode_CannotWriteFile:
      return "Cannot write to file";

    case ErrorCode_Custom:
    default:
      return "???";
    }
  }
}