Implement BUF_strnlen() and use it instead of strlen().
authorBen Laurie <ben@links.org>
Wed, 21 May 2014 10:54:54 +0000 (11:54 +0100)
committerBen Laurie <ben@links.org>
Wed, 21 May 2014 10:58:03 +0000 (11:58 +0100)
crypto/buffer/buf_str.c
crypto/buffer/buffer.h

index a464eb6e25605eb71df850ebba1c8f45f7a39628..58028ebac72f4f1ecc7578896afe9079101ca603 100644 (file)
 #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);
@@ -75,7 +85,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;
 
index 178e418282b2eb74ca575f61db678a393a151562..4300d01b3ff6a95253abb1a1f0b7bf7e92152823 100644 (file)
@@ -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);