]> granicus.if.org Git - php/commitdiff
add restart_psession and end_psession hooks
authorAndrey Hristov <andrey@php.net>
Fri, 8 Jan 2010 13:47:03 +0000 (13:47 +0000)
committerAndrey Hristov <andrey@php.net>
Fri, 8 Jan 2010 13:47:03 +0000 (13:47 +0000)
ext/mysqlnd/mysqlnd.c
ext/mysqlnd/mysqlnd.h
ext/mysqlnd/mysqlnd_net.c
ext/mysqlnd/mysqlnd_structs.h
ext/mysqlnd/mysqlnd_wireprotocol.c

index b66c458cde8a75c4779f90b36012991021e6ba50..b253b649076cede2e902cef6c1b42e9710064a0b 100644 (file)
@@ -411,26 +411,43 @@ MYSQLND_METHOD(mysqlnd_conn, set_server_option)(MYSQLND * const conn,
 PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn TSRMLS_DC)
 {
        DBG_ENTER("_mysqlnd_restart_psession");
+       conn->m->restart_psession(conn TSRMLS_CC);
+       DBG_VOID_RETURN;
+}
+/* }}} */
+
+
+/* {{{ _mysqlnd_end_psession */
+PHPAPI void _mysqlnd_end_psession(MYSQLND *conn TSRMLS_DC)
+{
+       DBG_ENTER("_mysqlnd_end_psession");
+       conn->m->end_psession(conn TSRMLS_CC);
+       DBG_VOID_RETURN;
+}
+/* }}} */
+
+/* {{{ mysqlnd_conn::restart_psession */
+static enum_func_status
+MYSQLND_METHOD(mysqlnd_conn, restart_psession)(MYSQLND * conn TSRMLS_DC)
+{
+       DBG_ENTER("mysqlnd_conn::restart_psession");
        MYSQLND_INC_CONN_STATISTIC(&conn->stats, STAT_CONNECT_REUSED);
        /* Free here what should not be seen by the next script */
        if (conn->last_message) {
                mnd_pefree(conn->last_message, conn->persistent);
                conn->last_message = NULL;
        }
-       /*
-         The thd zval cache is always freed on request shutdown, so this has happened already.
-         Don't touch the old value! Get new reference
-       */
-       DBG_VOID_RETURN;
+       DBG_RETURN(PASS);
 }
 /* }}} */
 
 
-/* {{{ _mysqlnd_end_psession */
-PHPAPI void _mysqlnd_end_psession(MYSQLND *conn TSRMLS_DC)
+/* {{{ mysqlnd_conn::end_psession */
+static enum_func_status
+MYSQLND_METHOD(mysqlnd_conn, end_psession)(MYSQLND * conn TSRMLS_DC)
 {
-       DBG_ENTER("_mysqlnd_end_psession");
-       DBG_VOID_RETURN;
+       DBG_ENTER("mysqlnd_conn::end_psession");
+       DBG_RETURN(PASS);
 }
 /* }}} */
 
@@ -2081,7 +2098,9 @@ MYSQLND_CLASS_METHODS_START(mysqlnd_conn)
        MYSQLND_METHOD_PRIVATE(mysqlnd_conn, set_state),
 
        MYSQLND_METHOD(mysqlnd_conn, simple_command),
-       MYSQLND_METHOD(mysqlnd_conn, simple_command_handle_response)
+       MYSQLND_METHOD(mysqlnd_conn, simple_command_handle_response),
+       MYSQLND_METHOD(mysqlnd_conn, restart_psession),
+       MYSQLND_METHOD(mysqlnd_conn, end_psession)
 MYSQLND_CLASS_METHODS_END;
 
 
index a3a38c73141e6acd76d6aee0c1750002f3da3ab7..03e55f737597806a775cdc421206c4b63ee9fbf2 100644 (file)
@@ -74,6 +74,9 @@ PHPAPI void ** _mysqlnd_plugin_get_plugin_result_data(const MYSQLND_RES * result
 PHPAPI void ** _mysqlnd_plugin_get_plugin_stmt_data(const MYSQLND_STMT * stmt, unsigned int plugin_id TSRMLS_DC);
 #define mysqlnd_plugin_get_plugin_stmt_data(s, p_id) _mysqlnd_plugin_get_plugin_stmt_data((s), (p_id) TSRMLS_CC)
 
+PHPAPI void ** _mysqlnd_plugin_get_plugin_protocol_data(const MYSQLND_PROTOCOL * protocol, unsigned int plugin_id TSRMLS_DC);
+#define mysqlnd_plugin_get_plugin_protocol_data(p, p_id) _mysqlnd_plugin_get_plugin_protocol_data((p), (p_id) TSRMLS_CC)
+
 
 PHPAPI struct st_mysqlnd_conn_methods * mysqlnd_conn_get_methods();
 PHPAPI void mysqlnd_conn_set_methods(struct st_mysqlnd_conn_methods *methods);
index ea0ece399cbffd183bb6c878b6c0aa2b63544614..63bd263fc906ca8ee772d8a3219b0dcc8d61e022 100644 (file)
@@ -661,7 +661,8 @@ MYSQLND_METHOD(mysqlnd_net, free_contents)(MYSQLND_NET * net TSRMLS_DC)
 MYSQLND_NET *
 mysqlnd_net_init(zend_bool persistent TSRMLS_DC)
 {
-       MYSQLND_NET * net = mnd_pecalloc(1, sizeof(MYSQLND_NET), persistent);
+       size_t alloc_size = sizeof(MYSQLND_NET) + mysqlnd_plugin_count() * sizeof(void *);
+       MYSQLND_NET * net = mnd_pecalloc(1, alloc_size, persistent);
 
        DBG_ENTER("mysqlnd_net_init");
        DBG_INF_FMT("persistent=%d", persistent);
@@ -719,6 +720,20 @@ mysqlnd_net_free(MYSQLND_NET * const net TSRMLS_DC)
 /* }}} */
 
 
+/* {{{ _mysqlnd_plugin_get_plugin_net_data */
+PHPAPI void ** _mysqlnd_plugin_get_plugin_net_data(const MYSQLND_NET * net, unsigned int plugin_id TSRMLS_DC)
+{
+       DBG_ENTER("_mysqlnd_plugin_get_plugin_net_data");
+       DBG_INF_FMT("plugin_id=%u", plugin_id);
+       if (!net || plugin_id >= mysqlnd_plugin_count()) {
+               return NULL;
+       }
+       DBG_RETURN((void *)((char *)net + sizeof(MYSQLND_NET) + plugin_id * sizeof(void *)));
+}
+/* }}} */
+
+
+
 /*
  * Local variables:
  * tab-width: 4
index 016b3bd32a720d7a9daf448b495f329c6de430ad..a186861b61630b0db0ba580b78c02e00054951b0 100644 (file)
@@ -336,6 +336,9 @@ struct st_mysqlnd_conn_methods
 
        enum_func_status        (*simple_command)(MYSQLND *conn, enum php_mysqlnd_server_command command, const char * const arg, size_t arg_len, enum php_mysql_packet_type ok_packet, zend_bool silent, zend_bool ignore_upsert_status TSRMLS_DC);
        enum_func_status        (*simple_command_handle_response)(MYSQLND *conn, enum php_mysql_packet_type ok_packet, zend_bool silent, enum php_mysqlnd_server_command command, zend_bool ignore_upsert_status TSRMLS_DC);
+
+       enum_func_status        (*restart_psession)(MYSQLND *conn TSRMLS_DC);
+       enum_func_status        (*end_psession)(MYSQLND *conn TSRMLS_DC);
 };
 
 
index 277ad00ab46e7047632ca06472e345f59e495f16..7ec96dc86624771f57eb9b44fb2914287dee4fda 100644 (file)
@@ -1974,6 +1974,19 @@ mysqlnd_protocol_free(MYSQLND_PROTOCOL * const protocol TSRMLS_DC)
 /* }}} */
 
 
+/* {{{ _mysqlnd_plugin_get_plugin_protocol_data */
+PHPAPI void ** _mysqlnd_plugin_get_plugin_protocol_data(const MYSQLND_PROTOCOL * protocol, unsigned int plugin_id TSRMLS_DC)
+{
+       DBG_ENTER("_mysqlnd_plugin_get_plugin_protocol_data");
+       DBG_INF_FMT("plugin_id=%u", plugin_id);
+       if (!protocol || plugin_id >= mysqlnd_plugin_count()) {
+               return NULL;
+       }
+       DBG_RETURN((void *)((char *)protocol + sizeof(MYSQLND_PROTOCOL) + plugin_id * sizeof(void *)));
+}
+/* }}} */
+
+
 /*
  * Local variables:
  * tab-width: 4