= nng_strdup(3) // // Copyright 2018 Staysail Systems, Inc. // Copyright 2018 Capitar IT Group BV // // This document is supplied under the terms of the MIT License, a // copy of which should be located in the distribution where this // file was obtained (LICENSE.txt). A copy of the license may also be // found online at https://opensource.org/licenses/MIT. // == NAME nng_strdup - duplicate string == SYNOPSIS [source, c] ---- #include char *nng_strdup(const char *src); ---- == DESCRIPTION The `nng_strdup()` duplicates the string _src_ and returns it. This is logically equiavlent to using `<>` to allocate a region of memory of `strlen(s) + 1` bytes, and then using `strcpy()` to copy the string into the destination before returning it. The returned string should be deallocated with `<>`, or may be deallocated using the `<>` using the length of the returned string plus one (for the `NUL` terminating byte). IMPORTANT: Do not use the system `free()` or similar functions to deallocate the string, since those may use a different memory arena! == RETURN VALUES This function returns the new string on success, and `NULL` on failure. == ERRORS No errors are returned, but a `NULL` return value should be treated the same as `NNG_ENOMEM`. == SEE ALSO <>, <>, <>