You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

strerror_override.c 2.1 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #define STRERROR_OVERRIDE_IMPL 1
  2. #include "strerror_override.h"
  3. /*
  4. * Override strerror() to get consistent output across platforms.
  5. */
  6. static struct {
  7. int errno_value;
  8. const char *errno_str;
  9. } errno_list[] = {
  10. /* clang-format off */
  11. #define STRINGIFY(x) #x
  12. #define ENTRY(x) {x, &STRINGIFY(undef_ ## x)[6]}
  13. ENTRY(EPERM),
  14. ENTRY(ENOENT),
  15. ENTRY(ESRCH),
  16. ENTRY(EINTR),
  17. ENTRY(EIO),
  18. ENTRY(ENXIO),
  19. ENTRY(E2BIG),
  20. ENTRY(ENOEXEC),
  21. ENTRY(EBADF),
  22. ENTRY(ECHILD),
  23. ENTRY(EDEADLK),
  24. ENTRY(ENOMEM),
  25. ENTRY(EACCES),
  26. ENTRY(EFAULT),
  27. #ifdef ENOTBLK
  28. ENTRY(ENOTBLK),
  29. #endif
  30. ENTRY(EBUSY),
  31. ENTRY(EEXIST),
  32. ENTRY(EXDEV),
  33. ENTRY(ENODEV),
  34. ENTRY(ENOTDIR),
  35. ENTRY(EISDIR),
  36. ENTRY(EINVAL),
  37. ENTRY(ENFILE),
  38. ENTRY(EMFILE),
  39. ENTRY(ENOTTY),
  40. #ifdef ETXTBSY
  41. ENTRY(ETXTBSY),
  42. #endif
  43. ENTRY(EFBIG),
  44. ENTRY(ENOSPC),
  45. ENTRY(ESPIPE),
  46. ENTRY(EROFS),
  47. ENTRY(EMLINK),
  48. ENTRY(EPIPE),
  49. ENTRY(EDOM),
  50. ENTRY(ERANGE),
  51. ENTRY(EAGAIN),
  52. { 0, (char *)0 }
  53. };
  54. /* clang-format on */
  55. // Enabled during tests
  56. int _json_c_strerror_enable = 0;
  57. #define PREFIX "ERRNO="
  58. static char errno_buf[128] = PREFIX;
  59. char *_json_c_strerror(int errno_in)
  60. {
  61. int start_idx;
  62. char digbuf[20];
  63. int ii, jj;
  64. if (!_json_c_strerror_enable)
  65. return strerror(errno_in);
  66. // Avoid standard functions, so we don't need to include any
  67. // headers, or guess at signatures.
  68. for (ii = 0; errno_list[ii].errno_str != (char *)0; ii++)
  69. {
  70. const char *errno_str = errno_list[ii].errno_str;
  71. if (errno_list[ii].errno_value != errno_in)
  72. continue;
  73. for (start_idx = sizeof(PREFIX) - 1, jj = 0; errno_str[jj] != '\0'; jj++, start_idx++)
  74. {
  75. errno_buf[start_idx] = errno_str[jj];
  76. }
  77. errno_buf[start_idx] = '\0';
  78. return errno_buf;
  79. }
  80. // It's not one of the known errno values, return the numeric value.
  81. for (ii = 0; errno_in > 10; errno_in /= 10, ii++)
  82. {
  83. digbuf[ii] = "0123456789"[(errno_in % 10)];
  84. }
  85. digbuf[ii] = "0123456789"[(errno_in % 10)];
  86. // Reverse the digits
  87. for (start_idx = sizeof(PREFIX) - 1 ; ii >= 0; ii--, start_idx++)
  88. {
  89. errno_buf[start_idx] = digbuf[ii];
  90. }
  91. return errno_buf;
  92. }