1
0

Error.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /* vim: set expandtab ts=4 sw=4: */
  2. /*
  3. * You may redistribute this program and/or modify it under the terms of
  4. * the GNU General Public License as published by the Free Software Foundation,
  5. * either version 3 of the License, or (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  14. */
  15. #ifndef Error_H
  16. #define Error_H
  17. /** No error, everything is ok. */
  18. #define Error_NONE 0
  19. /** The switch label was malformed. */
  20. #define Error_MALFORMED_ADDRESS 1
  21. /** Packet dropped because link is congested. */
  22. #define Error_FLOOD 2
  23. /** Packet dropped because node has oversent its limit. */
  24. #define Error_LINK_LIMIT_EXCEEDED 3
  25. /** Message too big to send. */
  26. #define Error_OVERSIZE_MESSAGE 4
  27. /** Message smaller than expected headers. */
  28. #define Error_UNDERSIZE_MESSAGE 5
  29. /** Authentication failed. */
  30. #define Error_AUTHENTICATION 6
  31. /** Header is invalid or checksum failed. */
  32. #define Error_INVALID 7
  33. /** Message could not be sent to its destination through no fault of the sender. */
  34. #define Error_UNDELIVERABLE 8
  35. /** The route enters and leaves through the same interface in one switch. */
  36. #define Error_LOOP_ROUTE 9
  37. /** The switch is unable to represent the return path. */
  38. #define Error_RETURN_PATH_INVALID 10
  39. static inline char* Error_strerror(int err)
  40. {
  41. switch (err) {
  42. case Error_NONE: return "Error_NONE";
  43. case Error_MALFORMED_ADDRESS: return "Error_MALFORMED_ADDRESS";
  44. case Error_FLOOD: return "Error_FLOOD";
  45. case Error_LINK_LIMIT_EXCEEDED: return "Error_LINK_LIMIT_EXCEEDED";
  46. case Error_OVERSIZE_MESSAGE: return "Error_OVERSIZE_MESSAGE";
  47. case Error_UNDERSIZE_MESSAGE: return "Error_UNDERSIZE_MESSAGE";
  48. case Error_AUTHENTICATION: return "Error_AUTHENTICATION";
  49. case Error_INVALID: return "Error_INVALID";
  50. case Error_UNDELIVERABLE: return "Error_UNDELIVERABLE";
  51. case Error_LOOP_ROUTE: return "Error_LOOP_ROUTE";
  52. case Error_RETURN_PATH_INVALID: return "Error_RETURN_PATH_INVALID";
  53. default: return "UNKNOWN";
  54. }
  55. }
  56. #endif