-
Notifications
You must be signed in to change notification settings - Fork 0
/
c.c
74 lines (35 loc) · 1.17 KB
/
c.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* File : strxcat.c
Author : Richard A. O'Keefe.
Updated: 25 may 1984
Defines: strxcat()
strxcat(dst, src1, ..., srcn, NullS)
moves the concatenation of dst,src1,...,srcn to dst, terminates it
with a NUL character, and returns the original value of dst.
It is just like strcat except that it concatenates multiple sources.
Equivalence: strxcat(d, s1, ..., sn) <=> strxcpy(d, d, s1, ..., sn).
Beware: the last argument should be the null character pointer.
Take VERY great care not to omit it! Also be careful to use NullS
and NOT to use 0, as on some machines 0 is not the same size as a
character pointer, or not the same bit pattern as NullS.
*/
#include "strings.h"
#include <varargs.h>
/*VARARGS*/
char *strxcat(va_alist)
va_dcl
{
va_list pvar;
register char *dst, *src;
char *bogus;
va_start(pvar);
dst = va_arg(pvar, char *);
bogus = dst;
while (*dst) dst++;
src = va_arg(pvar, char *);
while (src != NullS) {
while (*dst++ = *src++) ;
dst--;
src = va_arg(pvar, char *);
}
return bogus;
}