convert_to_string_ex(str);
if (!Z_STRLEN_PP(str)) {
- RETURN_FALSE;
+ RETURN_EMPTY_STRING();
}
ZVAL_STRINGL(return_value, Z_STRVAL_PP(str), Z_STRLEN_PP(str), 1);
convert_to_string_ex(str);
if (!Z_STRLEN_PP(str)) {
- RETURN_FALSE;
+ RETURN_EMPTY_STRING();
}
ZVAL_STRINGL(return_value, Z_STRVAL_PP(str), Z_STRLEN_PP(str), 1);
{
char *s, *t;
int l;
- char escape_char='\\';
if (len != NULL) {
l = *len;
(*len)--;
l--;
}
- }
- *s++ = *t++;
+ *s++ = *t++;
+ } else if (*t=='\\' && l>0 && t[1]=='0') {
+ *s++='\0';
+ t += 2;
+ if (len != NULL)
+ (*len)--;
+ l--;
+ } else {
+ *s++ = *t++;
+ }
l--;
}
*s = '\0';
while (l > 0) {
- if (*t == escape_char) {
+ if (*t == '\\') {
t++; /* skip the slash */
if (len != NULL)
(*len)--;
PHPAPI int
php_version_compare(const char *orig_ver1, const char *orig_ver2)
{
- char *ver1 = php_canonicalize_version(orig_ver1);
- char *ver2 = php_canonicalize_version(orig_ver2);
+ char *ver1;
+ char *ver2;
char *p1, *p2, *n1, *n2;
long l1, l2;
int compare = 0;
+ if (!*orig_ver1 || !*orig_ver2) {
+ if (!*orig_ver1 && !*orig_ver2) {
+ return 0;
+ } else {
+ return *orig_ver1 ? 1 : -1;
+ }
+ }
+ ver1 = php_canonicalize_version(orig_ver1);
+ ver2 = php_canonicalize_version(orig_ver2);
p1 = n1 = ver1;
p2 = n2 = ver2;
while (*p1 && *p2 && n1 && n2) {
if (argc == 2) {
RETURN_LONG(compare);
}
- if (!strcmp(op, "<") || !strcmp(op, "lt")) {
+ if (!strncmp(op, "<", op_len) || !strncmp(op, "lt", op_len)) {
RETURN_BOOL(compare == -1);
}
- if (!strcmp(op, "<=") || !strcmp(op, "le")) {
+ if (!strncmp(op, "<=", op_len) || !strncmp(op, "le", op_len)) {
RETURN_BOOL(compare != 1);
}
- if (!strcmp(op, ">") || !strcmp(op, "gt")) {
+ if (!strncmp(op, ">", op_len) || !strncmp(op, "gt", op_len)) {
RETURN_BOOL(compare == 1);
}
- if (!strcmp(op, ">=") || !strcmp(op, "ge")) {
+ if (!strncmp(op, ">=", op_len) || !strncmp(op, "ge", op_len)) {
RETURN_BOOL(compare != -1);
}
- if (!strcmp(op, "==") || !strcmp(op, "=") || !strcmp(op, "eq")) {
+ if (!strncmp(op, "==", op_len) || !strncmp(op, "=", op_len) || !strncmp(op, "eq", op_len)) {
RETURN_BOOL(compare == 0);
}
- if (!strcmp(op, "!=") || !strcmp(op, "<>") || !strcmp(op, "ne")) {
+ if (!strncmp(op, "!=", op_len) || !strncmp(op, "<>", op_len) || !strncmp(op, "ne", op_len)) {
RETURN_BOOL(compare != 0);
}
RETURN_NULL();