return.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
  2. *
  3. * Gearmand client and server library.
  4. *
  5. * Copyright (C) 2011 Data Differential, http://datadifferential.com/
  6. * Copyright (C) 2008 Brian Aker, Eric Day
  7. * All rights reserved.
  8. *
  9. * Redistribution and use in source and binary forms, with or without
  10. * modification, are permitted provided that the following conditions are
  11. * met:
  12. *
  13. * * Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. *
  16. * * Redistributions in binary form must reproduce the above
  17. * copyright notice, this list of conditions and the following disclaimer
  18. * in the documentation and/or other materials provided with the
  19. * distribution.
  20. *
  21. * * The names of its contributors may not be used to endorse or
  22. * promote products derived from this software without specific prior
  23. * written permission.
  24. *
  25. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  26. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  27. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  28. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  29. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  30. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  31. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  32. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  33. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  34. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  35. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. */
  38. #pragma once
  39. /**
  40. * Return codes.
  41. */
  42. enum gearman_return_t
  43. {
  44. GEARMAN_SUCCESS,
  45. GEARMAN_IO_WAIT,
  46. GEARMAN_SHUTDOWN,
  47. GEARMAN_SHUTDOWN_GRACEFUL,
  48. GEARMAN_ERRNO,
  49. GEARMAN_EVENT, // DEPRECATED, SERVER ONLY
  50. GEARMAN_TOO_MANY_ARGS,
  51. GEARMAN_NO_ACTIVE_FDS, // No servers available
  52. GEARMAN_INVALID_MAGIC,
  53. GEARMAN_INVALID_COMMAND,
  54. GEARMAN_INVALID_PACKET,
  55. GEARMAN_UNEXPECTED_PACKET,
  56. GEARMAN_GETADDRINFO,
  57. GEARMAN_NO_SERVERS,
  58. GEARMAN_LOST_CONNECTION,
  59. GEARMAN_MEMORY_ALLOCATION_FAILURE,
  60. GEARMAN_JOB_EXISTS, // see gearman_client_job_status()
  61. GEARMAN_JOB_QUEUE_FULL,
  62. GEARMAN_SERVER_ERROR,
  63. GEARMAN_WORK_ERROR,
  64. GEARMAN_WORK_DATA,
  65. GEARMAN_WORK_WARNING,
  66. GEARMAN_WORK_STATUS,
  67. GEARMAN_WORK_EXCEPTION,
  68. GEARMAN_WORK_FAIL,
  69. GEARMAN_NOT_CONNECTED,
  70. GEARMAN_COULD_NOT_CONNECT,
  71. GEARMAN_SEND_IN_PROGRESS, // DEPRECATED, SERVER ONLY
  72. GEARMAN_RECV_IN_PROGRESS, // DEPRECATED, SERVER ONLY
  73. GEARMAN_NOT_FLUSHING,
  74. GEARMAN_DATA_TOO_LARGE,
  75. GEARMAN_INVALID_FUNCTION_NAME,
  76. GEARMAN_INVALID_WORKER_FUNCTION,
  77. GEARMAN_NO_REGISTERED_FUNCTION,
  78. GEARMAN_NO_REGISTERED_FUNCTIONS,
  79. GEARMAN_NO_JOBS,
  80. GEARMAN_ECHO_DATA_CORRUPTION,
  81. GEARMAN_NEED_WORKLOAD_FN,
  82. GEARMAN_PAUSE, // Used only in custom application for client return based on work status, exception, or warning.
  83. GEARMAN_UNKNOWN_STATE,
  84. GEARMAN_PTHREAD, // DEPRECATED, SERVER ONLY
  85. GEARMAN_PIPE_EOF, // DEPRECATED, SERVER ONLY
  86. GEARMAN_QUEUE_ERROR, // DEPRECATED, SERVER ONLY
  87. GEARMAN_FLUSH_DATA, // Internal state, should never be seen by either client or worker.
  88. GEARMAN_SEND_BUFFER_TOO_SMALL,
  89. GEARMAN_IGNORE_PACKET, // Internal only
  90. GEARMAN_UNKNOWN_OPTION, // DEPRECATED
  91. GEARMAN_TIMEOUT,
  92. GEARMAN_ARGUMENT_TOO_LARGE,
  93. GEARMAN_INVALID_ARGUMENT,
  94. GEARMAN_IN_PROGRESS, // See gearman_client_job_status()
  95. GEARMAN_INVALID_SERVER_OPTION, // Bad server option sent to server
  96. GEARMAN_JOB_NOT_FOUND, // Job did not exist on server
  97. GEARMAN_MAX_RETURN, /* Always add new error code before */
  98. GEARMAN_FAIL= GEARMAN_WORK_FAIL,
  99. GEARMAN_FATAL= GEARMAN_WORK_FAIL,
  100. GEARMAN_ERROR= GEARMAN_WORK_ERROR
  101. };
  102. static inline bool gearman_continue(enum gearman_return_t rc)
  103. {
  104. return rc == GEARMAN_IO_WAIT || rc == GEARMAN_IN_PROGRESS || rc == GEARMAN_PAUSE || rc == GEARMAN_JOB_EXISTS;
  105. }
  106. static inline bool gearman_failed(enum gearman_return_t rc)
  107. {
  108. return rc != GEARMAN_SUCCESS;
  109. }
  110. static inline bool gearman_success(enum gearman_return_t rc)
  111. {
  112. return rc == GEARMAN_SUCCESS;
  113. }
  114. #ifndef __cplusplus
  115. typedef enum gearman_return_t gearman_return_t;
  116. #endif