tony2001                Thu Jan 18 15:40:54 2007 UTC

  Modified files:              
    /php-src/ext/interbase      interbase.c 
  Log:
  use snprintf()
  
  
http://cvs.php.net/viewvc.cgi/php-src/ext/interbase/interbase.c?r1=1.231&r2=1.232&diff_format=u
Index: php-src/ext/interbase/interbase.c
diff -u php-src/ext/interbase/interbase.c:1.231 
php-src/ext/interbase/interbase.c:1.232
--- php-src/ext/interbase/interbase.c:1.231     Mon Jan  1 09:29:24 2007
+++ php-src/ext/interbase/interbase.c   Thu Jan 18 15:40:54 2007
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: interbase.c,v 1.231 2007/01/01 09:29:24 sebastian Exp $ */
+/* $Id: interbase.c,v 1.232 2007/01/18 15:40:54 tony2001 Exp $ */
 
 #ifdef HAVE_CONFIG_H
 #include "config.h"
@@ -588,22 +588,28 @@
        
 int _php_ibase_attach_db(char **args, int *len, long *largs, isc_db_handle *db 
TSRMLS_DC)
 {
-       short i;
+       short i, dpb_len, buf_len = 256;
        char dpb_buffer[256] = { isc_dpb_version1 }, *dpb;
 
        dpb = dpb_buffer + 1;
 
        for (i = 0; i < sizeof(dpb_args); ++i) {
-               if (dpb_args[i] && args[i] && len[i]) {
-                       dpb += sprintf(dpb, "%c%c%s", dpb_args[i],(unsigned 
char)len[i],args[i]);
+               if (dpb_args[i] && args[i] && len[i] && buf_len > 0) {
+                       dpb_len += snprintf(dpb, buf_len, "%c%c%s", 
dpb_args[i],(unsigned char)len[i],args[i]);
+                       dpb += dpb_len;
+                       buf_len -= dpb_len;
                }
        }
-       if (largs[BUF]) {
-               dpb += sprintf(dpb, "%c\2%c%c", isc_dpb_num_buffers, 
+       if (largs[BUF] && buf_len > 0) {
+               dpb_len += snprintf(dpb, buf_len, "%c\2%c%c", 
isc_dpb_num_buffers, 
                        (char)(largs[BUF] >> 8), (char)(largs[BUF] & 0xff));
+               dpb += dpb_len;
+               buf_len -= dpb_len;
        }
-       if (largs[SYNC]) {
-               dpb += sprintf(dpb, "%c\1%c", isc_dpb_force_write, largs[SYNC] 
== isc_spb_prp_wm_sync ? 1 : 0);
+       if (largs[SYNC] && buf_len > 0) {
+               dpb_len += sprintf(dpb, buf_len, "%c\1%c", isc_dpb_force_write, 
largs[SYNC] == isc_spb_prp_wm_sync ? 1 : 0);
+               dpb += dpb_len;
+               buf_len -= dpb_len;
        }
        if (isc_attach_database(IB_STATUS, (short)len[DB], args[DB], db, 
(short)(dpb-dpb_buffer), dpb_buffer)) {
                _php_ibase_error(TSRMLS_C);

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

Reply via email to