strncpy.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /* Copyright (C) 1991, 1997, 2003 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library 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 GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, write to the Free
  13. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  14. 02111-1307 USA. */
  15. #include <string.h>
  16. #include "memcopy.h"
  17. #undef strncpy
  18. char *
  19. strncpy (s1, s2, n)
  20. char *s1;
  21. const char *s2;
  22. size_t n;
  23. {
  24. reg_char c;
  25. char *s = s1;
  26. --s1;
  27. if (n >= 4)
  28. {
  29. size_t n4 = n >> 2;
  30. for (;;)
  31. {
  32. c = *s2++;
  33. *++s1 = c;
  34. if (c == '\0')
  35. break;
  36. c = *s2++;
  37. *++s1 = c;
  38. if (c == '\0')
  39. break;
  40. c = *s2++;
  41. *++s1 = c;
  42. if (c == '\0')
  43. break;
  44. c = *s2++;
  45. *++s1 = c;
  46. if (c == '\0')
  47. break;
  48. if (--n4 == 0)
  49. goto last_chars;
  50. }
  51. n = n - (s1 - s) - 1;
  52. if (n == 0)
  53. return s;
  54. goto zero_fill;
  55. }
  56. last_chars:
  57. n &= 3;
  58. if (n == 0)
  59. return s;
  60. do
  61. {
  62. c = *s2++;
  63. *++s1 = c;
  64. if (--n == 0)
  65. return s;
  66. }
  67. while (c != '\0');
  68. zero_fill:
  69. do
  70. *++s1 = '\0';
  71. while (--n > 0);
  72. return s;
  73. }