int attr_count, entry_count;
BerElement *ber;
char *attribute;
+ size_t attr_len;
char **ldap_value;
char *dn;
}
ldap_value_free(ldap_value);
- zend_hash_update(tmp1->value.ht, php_strtolower(attribute), strlen(attribute)+1, (void *) &tmp2, sizeof(pval *), NULL);
+ attr_len = strlen(attribute);
+ zend_hash_update(tmp1->value.ht, php_strtolower(attribute, attr_len), attr_len+1, (void *) &tmp2, sizeof(pval *), NULL);
add_index_string(tmp1, attr_count, attribute, 1);
attr_count++;
PHP_FUNCTION(str_repeat);
PHP_FUNCTION(substr_replace);
-extern PHPAPI char *php_strtoupper(char *s);
-extern PHPAPI char *php_strtolower(char *s);
+extern PHPAPI char *php_strtoupper(char *s, size_t len);
+extern PHPAPI char *php_strtolower(char *s, size_t len);
extern PHPAPI char *php_strtr(char *string, int len, char *str_from, char *str_to, int trlen);
extern PHPAPI char *php_addslashes(char *string, int length, int *new_length, int freeit);
extern PHPAPI char *php_addcslashes(char *string, int length, int *new_length, int freeit, char *what, int wlength);
}
/* }}} */
-PHPAPI char *php_strtoupper(char *s)
+PHPAPI char *php_strtoupper(char *s, size_t len)
{
char *c;
int ch;
+ int i;
c = s;
- while (*c) {
+ for (i=0; i<len; i++) {
ch = toupper((unsigned char)*c);
*c++ = ch;
}
*return_value = **arg;
zval_copy_ctor(return_value);
- php_strtoupper(return_value->value.str.val);
+ php_strtoupper(return_value->value.str.val, return_value->value.str.len);
}
/* }}} */
-PHPAPI char *php_strtolower(char *s)
+PHPAPI char *php_strtolower(char *s, size_t len)
{
register int ch;
char *c;
c = s;
- while (*c) {
+ for (i=0; i<len; i++) {
ch = tolower((unsigned char)*c);
*c++ = ch;
}
*return_value = **str;
zval_copy_ctor(return_value);
- ret = php_strtolower(return_value->value.str.val);
+ ret = php_strtolower(return_value->value.str.val, return_value->value.str.len);
}
/* }}} */
result_len = (*string)->value.str.len - l + (*repl)->value.str.len;
result = (char *)ecalloc(result_len + 1, sizeof(char *));
- strncat(result, (*string)->value.str.val, f);
- strcat(result, (*repl)->value.str.val);
- strcat(result, (*string)->value.str.val + f + l);
+ memcpy(result, (*string)->value.str.val, f);
+ memcpy(&result[f], (*repl)->value.str.val, (*repl)->value.str.len);
+ memcpy(&result[f + (*repl)->value.str.len], (*string)->value.str.val + f + l,
+ (*string)->value.str.len - f - l);
- RETVAL_STRING(result, 0);
+ RETVAL_STRINGL(result, result_len, 0);
}
/* }}} */