summaryrefslogtreecommitdiffstats
path: root/crypto/buffer
diff options
context:
space:
mode:
authorBen Laurie <ben@links.org>2014-05-21 11:54:54 +0100
committerBen Laurie <ben@links.org>2014-05-21 11:56:21 +0100
commited693e43329383c0d68455d83778cdc9748a074d (patch)
tree520883edfb4838bd9d5f2f22f242bf22cc5363eb /crypto/buffer
parenta2219f6be36d12f02b6420dd95f819cf364baf1d (diff)
Implement BUF_strnlen() and use it instead of strlen().
Diffstat (limited to 'crypto/buffer')
-rw-r--r--crypto/buffer/buf_str.c12
-rw-r--r--crypto/buffer/buffer.h1
2 files changed, 12 insertions, 1 deletions
diff --git a/crypto/buffer/buf_str.c b/crypto/buffer/buf_str.c
index 84236c7671..07840b57c4 100644
--- a/crypto/buffer/buf_str.c
+++ b/crypto/buffer/buf_str.c
@@ -60,6 +60,16 @@
#include "cryptlib.h"
#include <openssl/buffer.h>
+size_t BUF_strnlen(const char *str, size_t maxlen)
+ {
+ const char *p;
+
+ for (p = str; *p != '\0' && maxlen-- != 0; ++p)
+ ;
+
+ return p - str;
+ }
+
char *BUF_strdup(const char *str)
{
if (str == NULL) return(NULL);
@@ -73,7 +83,7 @@ char *BUF_strndup(const char *str, size_t siz)
if (str == NULL) return(NULL);
- len = strlen(str);
+ len = BUF_strnlen(str, siz);
if (siz > len)
siz = len;
diff --git a/crypto/buffer/buffer.h b/crypto/buffer/buffer.h
index f8da32b485..881c2da170 100644
--- a/crypto/buffer/buffer.h
+++ b/crypto/buffer/buffer.h
@@ -85,6 +85,7 @@ BUF_MEM *BUF_MEM_new(void);
void BUF_MEM_free(BUF_MEM *a);
int BUF_MEM_grow(BUF_MEM *str, size_t len);
int BUF_MEM_grow_clean(BUF_MEM *str, size_t len);
+size_t BUF_strnlen(const char *str, size_t maxlen);
char * BUF_strdup(const char *str);
char * BUF_strndup(const char *str, size_t siz);
void * BUF_memdup(const void *data, size_t siz);