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 1.8 kB

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