summaryrefslogtreecommitdiff
path: root/libc/stdlib/strdup.c
diff options
context:
space:
mode:
authorMarcus Huderle <huderlem@gmail.com>2017-12-27 16:22:00 -0600
committerGitHub <noreply@github.com>2017-12-27 16:22:00 -0600
commit6b611a3046a694d3972f2aa4df90d3ef78801217 (patch)
tree05f295c00cbbc1d5987a05da37e746fb841d4d83 /libc/stdlib/strdup.c
parent58c860d6c48324eba66dd19540db5584d832cf58 (diff)
parentd88495e3f4061a411e654c7307aa94ac8a98c94b (diff)
Merge pull request #13 from ProjectRevoTPP/libc
add libc building to agbcc.
Diffstat (limited to 'libc/stdlib/strdup.c')
-rw-r--r--libc/stdlib/strdup.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/libc/stdlib/strdup.c b/libc/stdlib/strdup.c
new file mode 100644
index 0000000..6261dbb
--- /dev/null
+++ b/libc/stdlib/strdup.c
@@ -0,0 +1,14 @@
+#include <stdlib.h>
+#include <string.h>
+
+char *
+_DEFUN (strdup, (str), _CONST char *str)
+{
+ size_t len = strlen (str) + 1;
+ char *copy = malloc (len);
+ if (copy)
+ {
+ memcpy (copy, str, len);
+ }
+ return copy;
+}