strlcpy.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // ECOin - Copyright (c) - 2014/2022 - GPLv3 - epsylon@riseup.net (https://03c8.net)
  2. /*
  3. * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com>
  4. *
  5. * Permission to use, copy, modify, and distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  10. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  11. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  12. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  13. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  14. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  15. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. #ifndef ECOIN_STRLCPY_H
  18. #define ECOIN_STRLCPY_H
  19. #include <stdlib.h>
  20. #include <string.h>
  21. /*
  22. * Copy src to string dst of size siz. At most siz-1 characters
  23. * will be copied. Always NUL terminates (unless siz == 0).
  24. * Returns strlen(src); if retval >= siz, truncation occurred.
  25. */
  26. inline size_t strlcpy(char *dst, const char *src, size_t siz)
  27. {
  28. char *d = dst;
  29. const char *s = src;
  30. size_t n = siz;
  31. /* Copy as many bytes as will fit */
  32. if (n != 0)
  33. {
  34. while (--n != 0)
  35. {
  36. if ((*d++ = *s++) == '\0')
  37. break;
  38. }
  39. }
  40. /* Not enough room in dst, add NUL and traverse rest of src */
  41. if (n == 0)
  42. {
  43. if (siz != 0)
  44. *d = '\0'; /* NUL-terminate dst */
  45. while (*s++)
  46. ;
  47. }
  48. return(s - src - 1); /* count does not include NUL */
  49. }
  50. /*
  51. * Appends src to string dst of size siz (unlike strncat, siz is the
  52. * full size of dst, not space left). At most siz-1 characters
  53. * will be copied. Always NUL terminates (unless siz <= strlen(dst)).
  54. * Returns strlen(src) + MIN(siz, strlen(initial dst)).
  55. * If retval >= siz, truncation occurred.
  56. */
  57. inline size_t strlcat(char *dst, const char *src, size_t siz)
  58. {
  59. char *d = dst;
  60. const char *s = src;
  61. size_t n = siz;
  62. size_t dlen;
  63. /* Find the end of dst and adjust bytes left but don't go past end */
  64. while (n-- != 0 && *d != '\0')
  65. d++;
  66. dlen = d - dst;
  67. n = siz - dlen;
  68. if (n == 0)
  69. return(dlen + strlen(s));
  70. while (*s != '\0')
  71. {
  72. if (n != 1)
  73. {
  74. *d++ = *s;
  75. n--;
  76. }
  77. s++;
  78. }
  79. *d = '\0';
  80. return(dlen + (s - src)); /* count does not include NUL */
  81. }
  82. #endif