iliaa           Wed Oct 29 19:49:34 2003 EDT

  Modified files:              
    /php-src    NEWS 
    /php-src/ext/standard       string.c php_string.h basic_functions.c 
  Log:
  Added substr_compare().
  
  
Index: php-src/NEWS
diff -u php-src/NEWS:1.1484 php-src/NEWS:1.1485
--- php-src/NEWS:1.1484 Wed Oct 29 17:18:24 2003
+++ php-src/NEWS        Wed Oct 29 19:49:32 2003
@@ -34,6 +34,7 @@
   . array_diff_uassoc(). (Andrey)
   . convert_uuencode(). (Ilia)
   . convert_uudecode(). (Ilia)
+  . substr_compare(). (Ilia)
   . pcntl_wait(). (GeorgeS)
 - Added "resume_pos" context option to "ftp://"; wrapper. (Sara)
 - Added optional parameter to OCIWriteTemporaryLob() to specify the type of LOB
Index: php-src/ext/standard/string.c
diff -u php-src/ext/standard/string.c:1.399 php-src/ext/standard/string.c:1.400
--- php-src/ext/standard/string.c:1.399 Sun Sep 28 22:23:40 2003
+++ php-src/ext/standard/string.c       Wed Oct 29 19:49:33 2003
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: string.c,v 1.399 2003/09/29 02:23:40 moriyoshi Exp $ */
+/* $Id: string.c,v 1.400 2003/10/30 00:49:33 iliaa Exp $ */
 
 /* Synced with php 3.0 revision 1.193 1999-06-16 [ssb] */
 
@@ -4658,6 +4658,35 @@
                RETURN_STRINGL(p, (haystack + haystack_len - p), 1);
        } else {
                RETURN_FALSE;
+       }
+}
+/* }}} */
+
+/* {{{ proto int substr_compare(string main_str, string str, int offset [, int length 
[, bool case_sensitivity]])
+   Binary safe optionally case insensitive comparison of 2 strings from an offset, up 
to length characters */
+PHP_FUNCTION(substr_compare)
+{
+       char *s1, *s2;
+       int s1_len, s2_len;
+       long offset, len=0;
+       zend_bool cs=0;
+       uint cmp_len;
+
+       if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "ssl|lb", &s1, &s1_len, 
&s2, &s2_len, &offset, &len, &cs) == FAILURE) {
+               RETURN_FALSE;
+       }
+
+       if (len && offset >= s1_len) {
+               php_error_docref(NULL TSRMLS_CC, E_WARNING, "The start position cannot 
exceed initial string length.");
+               RETURN_FALSE;
+       }
+
+       cmp_len = (uint) (len ? len : MAX(s2_len, (s1_len - offset)));
+
+       if (!cs) {
+               RETURN_LONG(zend_binary_strncmp(s1 + offset, (s1_len - offset), s2, 
s2_len, cmp_len));
+       } else {
+               RETURN_LONG(zend_binary_strncasecmp(s1 + offset, (s1_len - offset), 
s2, s2_len, cmp_len));
        }
 }
 /* }}} */
Index: php-src/ext/standard/php_string.h
diff -u php-src/ext/standard/php_string.h:1.79 php-src/ext/standard/php_string.h:1.80
--- php-src/ext/standard/php_string.h:1.79      Thu Jul 24 21:03:39 2003
+++ php-src/ext/standard/php_string.h   Wed Oct 29 19:49:33 2003
@@ -17,7 +17,7 @@
    +----------------------------------------------------------------------+
 */
 
-/* $Id: php_string.h,v 1.79 2003/07/25 01:03:39 pollita Exp $ */
+/* $Id: php_string.h,v 1.80 2003/10/30 00:49:33 iliaa Exp $ */
 
 /* Synced with php 3.0 revision 1.43 1999-06-16 [ssb] */
 
@@ -89,6 +89,7 @@
 PHP_FUNCTION(str_word_count);
 PHP_FUNCTION(str_split);
 PHP_FUNCTION(strpbrk);
+PHP_FUNCTION(substr_compare);
 #ifdef HAVE_STRCOLL
 PHP_FUNCTION(strcoll);
 #endif
Index: php-src/ext/standard/basic_functions.c
diff -u php-src/ext/standard/basic_functions.c:1.636 
php-src/ext/standard/basic_functions.c:1.637
--- php-src/ext/standard/basic_functions.c:1.636        Mon Oct 27 23:02:11 2003
+++ php-src/ext/standard/basic_functions.c      Wed Oct 29 19:49:33 2003
@@ -17,7 +17,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: basic_functions.c,v 1.636 2003/10/28 04:02:11 iliaa Exp $ */
+/* $Id: basic_functions.c,v 1.637 2003/10/30 00:49:33 iliaa Exp $ */
 
 #include "php.h"
 #include "php_streams.h"
@@ -374,6 +374,7 @@
        PHP_FE(str_word_count,                                                         
                                                 NULL)
        PHP_FE(str_split,                                                              
                                                 NULL)
        PHP_FE(strpbrk,                                                                
                                                 NULL)
+       PHP_FE(substr_compare,                                                         
                                                 NULL)
 
 #ifdef HAVE_STRCOLL
        PHP_FE(strcoll,                                                                
                                                 NULL)

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to