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