2012-05-22 19:43:11 +02:00
|
|
|
/*
|
|
|
|
+----------------------------------------------------------------------+
|
|
|
|
| PHP Version 5 |
|
|
|
|
+----------------------------------------------------------------------+
|
2012-05-28 05:10:49 +02:00
|
|
|
| Copyright (c) 1997-2012 The PHP Group |
|
2012-05-22 19:43:11 +02:00
|
|
|
+----------------------------------------------------------------------+
|
|
|
|
| This source file is subject to version 3.01 of the PHP license, |
|
|
|
|
| that is bundled with this package in the file LICENSE, and is |
|
|
|
|
| available through the world-wide-web at the following url: |
|
|
|
|
| http://www.php.net/license/3_01.txt |
|
|
|
|
| If you did not receive a copy of the PHP license and are unable to |
|
|
|
|
| obtain it through the world-wide-web, please send a note to |
|
|
|
|
| license@php.net so we can mail you a copy immediately. |
|
|
|
|
+----------------------------------------------------------------------+
|
2012-05-28 05:10:49 +02:00
|
|
|
| Authors: Shuhei Tanuma <chobieeee@php.net> |
|
2012-05-22 19:43:11 +02:00
|
|
|
+----------------------------------------------------------------------+
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include "php_uv.h"
|
2012-06-25 18:04:16 +02:00
|
|
|
#include "ext/standard/info.h"
|
2012-05-22 19:43:11 +02:00
|
|
|
|
2012-06-01 18:37:29 +02:00
|
|
|
#ifndef PHP_UV_DEBUG
|
2012-07-01 01:32:05 +02:00
|
|
|
#define PHP_UV_DEBUG 0
|
2012-06-01 18:37:29 +02:00
|
|
|
#endif
|
|
|
|
|
2012-06-28 15:49:08 +02:00
|
|
|
#define PHP_UV_INIT_UV(uv, uv_type) \
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t)); \
|
|
|
|
if (!uv) { \
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "emalloc failed"); \
|
|
|
|
return; \
|
|
|
|
} else { \
|
|
|
|
uv->type = uv_type; \
|
|
|
|
PHP_UV_INIT_ZVALS(uv) \
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx); \
|
|
|
|
uv->resource_id = PHP_UV_LIST_INSERT(uv, uv_resource_handle); \
|
|
|
|
}
|
2012-05-27 15:28:26 +02:00
|
|
|
|
2012-06-28 15:49:08 +02:00
|
|
|
#define PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop) \
|
|
|
|
{ \
|
|
|
|
if (zloop != NULL) { \
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle); \
|
|
|
|
} else { \
|
|
|
|
loop = uv_default_loop(); \
|
|
|
|
} \
|
|
|
|
}
|
2012-05-29 18:47:30 +02:00
|
|
|
|
2012-06-28 15:49:08 +02:00
|
|
|
#define PHP_UV_FS_ASYNC(loop, func, ...) \
|
|
|
|
error = uv_fs_##func(loop, (uv_fs_t*)&uv->uv.fs, __VA_ARGS__, php_uv_fs_cb); \
|
|
|
|
if (error) { \
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_##func failed"); \
|
|
|
|
return; \
|
|
|
|
}
|
2012-05-29 18:47:30 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
#define PHP_UV_INIT_ZVALS(uv) \
|
2012-05-28 05:29:15 +02:00
|
|
|
{ \
|
2012-05-28 18:12:09 +02:00
|
|
|
uv->address = NULL; \
|
2012-05-28 05:29:15 +02:00
|
|
|
uv->listen_cb = NULL; \
|
|
|
|
uv->read_cb = NULL; \
|
2012-07-01 01:25:16 +02:00
|
|
|
uv->read2_cb = NULL; \
|
2012-05-28 05:29:15 +02:00
|
|
|
uv->write_cb = NULL; \
|
|
|
|
uv->close_cb = NULL; \
|
2012-06-30 18:55:48 +02:00
|
|
|
uv->shutdown_cb = NULL; \
|
2012-05-28 05:29:15 +02:00
|
|
|
uv->timer_cb = NULL; \
|
|
|
|
uv->idle_cb = NULL; \
|
2012-05-28 18:12:09 +02:00
|
|
|
uv->connect_cb = NULL; \
|
2012-05-29 18:47:30 +02:00
|
|
|
uv->getaddr_cb = NULL; \
|
|
|
|
uv->udp_recv_cb = NULL; \
|
|
|
|
uv->udp_send_cb = NULL; \
|
2012-05-31 19:23:34 +02:00
|
|
|
uv->pipe_connect_cb = NULL; \
|
2012-06-14 15:24:19 +02:00
|
|
|
uv->proc_close_cb = NULL; \
|
2012-06-17 15:50:18 +02:00
|
|
|
uv->prepare_cb = NULL; \
|
2012-06-17 16:04:54 +02:00
|
|
|
uv->check_cb = NULL; \
|
2012-06-17 18:32:50 +02:00
|
|
|
uv->work_cb = NULL; \
|
|
|
|
uv->async_cb = NULL; \
|
|
|
|
uv->after_work_cb = NULL; \
|
2012-06-20 05:40:39 +02:00
|
|
|
uv->fs_cb = NULL; \
|
2012-06-23 07:18:38 +02:00
|
|
|
uv->fs_event_cb = NULL; \
|
2012-05-28 05:29:15 +02:00
|
|
|
}
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
#if PHP_UV_DEBUG>=1
|
2012-06-30 09:45:40 +02:00
|
|
|
#define PHP_UV_DEBUG_PRINT(format, ...) fprintf(stderr, format, ## __VA_ARGS__)
|
2012-06-29 17:42:33 +02:00
|
|
|
#else
|
|
|
|
#define PHP_UV_DEBUG_PRINT(format, ...)
|
|
|
|
#endif
|
|
|
|
|
2012-06-29 17:58:20 +02:00
|
|
|
#if PHP_UV_DEBUG>=1
|
|
|
|
#define PHP_UV_DEBUG_RESOURCE_REFCOUNT(name, resource_id) \
|
|
|
|
{ \
|
|
|
|
zend_rsrc_list_entry *le; \
|
|
|
|
if (zend_hash_index_find(&EG(regular_list), resource_id, (void **) &le)==SUCCESS) { \
|
2012-06-30 09:45:40 +02:00
|
|
|
printf("# %s del(%d): %d->%d\n", #name, resource_id, le->refcount, le->refcount-1); \
|
2012-06-29 17:58:20 +02:00
|
|
|
} else { \
|
2012-06-30 09:45:40 +02:00
|
|
|
printf("# can't find (%s)", #name); \
|
2012-06-29 17:58:20 +02:00
|
|
|
} \
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#define PHP_UV_DEBUG_RESOURCE_REFCOUNT(name, resource_id)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2012-06-28 15:49:08 +02:00
|
|
|
extern void php_uv_init(TSRMLS_D);
|
|
|
|
extern zend_class_entry *uv_class_entry;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
uv_write_t req;
|
|
|
|
uv_buf_t buf;
|
|
|
|
} write_req_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
uv_udp_send_t req;
|
|
|
|
uv_buf_t buf;
|
|
|
|
} send_req_t;
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
/* static variables */
|
|
|
|
|
|
|
|
static uv_loop_t *_php_uv_default_loop;
|
|
|
|
|
|
|
|
/* resources */
|
2012-05-28 05:29:15 +02:00
|
|
|
|
2012-05-28 14:52:09 +02:00
|
|
|
static int uv_resource_handle;
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
static int uv_ares_handle;
|
2012-05-28 14:52:09 +02:00
|
|
|
|
2012-05-28 15:18:36 +02:00
|
|
|
static int uv_loop_handle;
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
static int uv_sockaddr_handle;
|
2012-05-28 15:18:36 +02:00
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
static int uv_lock_handle;
|
2012-06-16 10:22:29 +02:00
|
|
|
|
2012-07-01 06:15:14 +02:00
|
|
|
static int uv_httpparser_handle;
|
|
|
|
|
2012-06-21 02:43:20 +02:00
|
|
|
static char uv_fs_read_buf[10];
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
/* declarations */
|
2012-05-28 14:52:09 +02:00
|
|
|
|
|
|
|
void php_uv_init(TSRMLS_D);
|
|
|
|
|
2012-05-30 23:59:21 +02:00
|
|
|
static inline uv_stream_t* php_uv_get_current_stream(php_uv_t *uv);
|
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
/**
|
|
|
|
* execute callback
|
|
|
|
*
|
|
|
|
* @param zval** retval_ptr non-initialized pointer. this will be allocate from zend_call_function
|
|
|
|
* @param zval* callback callable object
|
|
|
|
* @param zval** params parameters.
|
|
|
|
* @param int param_count
|
|
|
|
* @return int (maybe..)
|
|
|
|
*/
|
2012-05-30 15:18:50 +02:00
|
|
|
static int php_uv_do_callback(zval **retval_ptr, zval *callback, zval ***params, int param_count TSRMLS_DC);
|
2012-05-29 05:37:08 +02:00
|
|
|
|
2012-05-28 14:52:09 +02:00
|
|
|
static void php_uv_close_cb(uv_handle_t *handle);
|
|
|
|
|
|
|
|
void static destruct_uv(zend_rsrc_list_entry *rsrc TSRMLS_DC);
|
|
|
|
|
|
|
|
static void php_uv_tcp_connect_cb(uv_connect_t *conn_req, int status);
|
|
|
|
|
|
|
|
static void php_uv_write_cb(uv_write_t* req, int status);
|
|
|
|
|
|
|
|
static void php_uv_listen_cb(uv_stream_t* server, int status);
|
|
|
|
|
|
|
|
static void php_uv_close_cb2(uv_handle_t *handle);
|
|
|
|
|
|
|
|
static void php_uv_shutdown_cb(uv_shutdown_t* req, int status);
|
|
|
|
|
|
|
|
static void php_uv_read_cb(uv_stream_t* handle, ssize_t nread, uv_buf_t buf);
|
|
|
|
|
2012-07-01 01:25:16 +02:00
|
|
|
static void php_uv_read2_cb(uv_pipe_t* handle, ssize_t nread, uv_buf_t buf, uv_handle_type pending);
|
|
|
|
|
2012-05-28 14:52:09 +02:00
|
|
|
static uv_buf_t php_uv_read_alloc(uv_handle_t* handle, size_t suggested_size);
|
|
|
|
|
|
|
|
static void php_uv_close_cb(uv_handle_t *handle);
|
|
|
|
|
|
|
|
static void php_uv_timer_cb(uv_timer_t *handle, int status);
|
|
|
|
|
|
|
|
static void php_uv_idle_cb(uv_timer_t *handle, int status);
|
|
|
|
|
2012-06-23 05:01:10 +02:00
|
|
|
/* util */
|
|
|
|
|
2012-06-23 13:27:30 +02:00
|
|
|
static zval *php_uv_address_to_zval(const struct sockaddr *addr)
|
|
|
|
{
|
|
|
|
zval *tmp;
|
|
|
|
char ip[INET6_ADDRSTRLEN];
|
2012-06-25 16:59:49 +02:00
|
|
|
const struct sockaddr_in *a4;
|
|
|
|
const struct sockaddr_in6 *a6;
|
2012-06-23 13:27:30 +02:00
|
|
|
int port;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
array_init(tmp);
|
|
|
|
|
|
|
|
switch (addr->sa_family) {
|
|
|
|
case AF_INET6:
|
|
|
|
{
|
2012-06-25 18:04:16 +02:00
|
|
|
a6 = (const struct sockaddr_in6 *)addr;
|
2012-06-23 13:27:30 +02:00
|
|
|
uv_inet_ntop(AF_INET, &a6->sin6_addr, ip, sizeof ip);
|
|
|
|
port = ntohs(a6->sin6_port);
|
|
|
|
|
|
|
|
add_assoc_string_ex(tmp, "address",sizeof("address"), ip, 1);
|
|
|
|
add_assoc_long_ex(tmp, "port", sizeof("port"), port);
|
|
|
|
add_assoc_string_ex(tmp, "family",sizeof("address"), "IPv6", 1);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AF_INET:
|
|
|
|
{
|
|
|
|
a4 = (const struct sockaddr_in *)addr;
|
|
|
|
uv_inet_ntop(AF_INET, &a4->sin_addr, ip, sizeof ip);
|
|
|
|
port = ntohs(a4->sin_port);
|
|
|
|
|
|
|
|
add_assoc_string_ex(tmp, "address",sizeof("address"), ip, 1);
|
|
|
|
add_assoc_long_ex(tmp, "port", sizeof("port"), port);
|
|
|
|
add_assoc_string_ex(tmp, "family",sizeof("address"), "IPv4", 1);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
2012-06-23 06:00:27 +02:00
|
|
|
static zval *php_uv_make_stat(const uv_statbuf_t *s)
|
2012-06-23 05:01:10 +02:00
|
|
|
{
|
|
|
|
zval *tmp;
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
array_init(tmp);
|
|
|
|
|
2012-06-23 06:00:27 +02:00
|
|
|
add_assoc_long_ex(tmp, "dev", sizeof("dev"), s->st_dev);
|
|
|
|
add_assoc_long_ex(tmp, "ino", sizeof("ino"), s->st_ino);
|
|
|
|
add_assoc_long_ex(tmp, "mode", sizeof("mode"), s->st_mode);
|
|
|
|
add_assoc_long_ex(tmp, "nlink", sizeof("nlink"), s->st_nlink);
|
|
|
|
add_assoc_long_ex(tmp, "uid", sizeof("uid"), s->st_uid);
|
|
|
|
add_assoc_long_ex(tmp, "gid", sizeof("gid"), s->st_gid);
|
|
|
|
add_assoc_long_ex(tmp, "rdev", sizeof("rdev"), s->st_rdev);
|
|
|
|
add_assoc_long_ex(tmp, "size", sizeof("size"), s->st_size);
|
|
|
|
|
2012-06-25 17:10:40 +02:00
|
|
|
#ifndef PHP_WIN32
|
2012-06-23 06:00:27 +02:00
|
|
|
add_assoc_long_ex(tmp, "blksize", sizeof("blksize"), s->st_blksize);
|
|
|
|
add_assoc_long_ex(tmp, "blocks", sizeof("blocks"), s->st_blocks);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
add_assoc_long_ex(tmp, "atime", sizeof("atime"), s->st_atime);
|
|
|
|
add_assoc_long_ex(tmp, "mtime", sizeof("mtime"), s->st_mtime);
|
|
|
|
add_assoc_long_ex(tmp, "ctime", sizeof("ctime"), s->st_ctime);
|
|
|
|
|
|
|
|
|
2012-06-23 05:01:10 +02:00
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
/* destructor */
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
void static destruct_uv_lock(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
2012-06-16 10:22:29 +02:00
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock = (php_uv_lock_t *)rsrc->ptr;
|
2012-06-30 07:42:06 +02:00
|
|
|
if (lock->type == IS_UV_RWLOCK) {
|
|
|
|
if (lock->locked == 0x01) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_rwlock: unlocked resoruce detected. force rdunlock resource.");
|
|
|
|
uv_rwlock_rdunlock(&lock->lock.rwlock);
|
|
|
|
lock->locked = 0x00;
|
|
|
|
} else if (lock->locked == 0x02) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_rwlock: unlocked resoruce detected. force wrunlock resource.");
|
|
|
|
uv_rwlock_wrunlock(&lock->lock.rwlock);
|
|
|
|
lock->locked = 0x00;
|
|
|
|
}
|
|
|
|
uv_rwlock_destroy(&lock->lock.rwlock);
|
|
|
|
} else if (lock->type == IS_UV_MUTEX) {
|
|
|
|
if (lock->locked == 0x01) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_mutex: unlocked resoruce detected. force unlock resource.");
|
|
|
|
uv_mutex_unlock(&lock->lock.mutex);
|
|
|
|
lock->locked = 0x00;
|
|
|
|
}
|
|
|
|
uv_mutex_destroy(&lock->lock.mutex);
|
2012-06-30 07:10:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
efree(lock);
|
2012-06-16 10:22:29 +02:00
|
|
|
}
|
|
|
|
|
2012-05-28 15:18:36 +02:00
|
|
|
void static destruct_uv_loop(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
|
|
|
{
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_loop_t *loop = (uv_loop_t *)rsrc->ptr;
|
2012-05-28 15:18:36 +02:00
|
|
|
if (loop != _php_uv_default_loop) {
|
|
|
|
uv_loop_delete(loop);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
void static destruct_uv_sockaddr(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
|
|
|
{
|
|
|
|
php_uv_sockaddr_t *addr = (php_uv_sockaddr_t *)rsrc->ptr;
|
|
|
|
efree(addr);
|
|
|
|
}
|
|
|
|
|
2012-05-28 15:18:36 +02:00
|
|
|
static uv_loop_t *php_uv_default_loop()
|
|
|
|
{
|
|
|
|
if (_php_uv_default_loop == NULL) {
|
|
|
|
_php_uv_default_loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
return _php_uv_default_loop;
|
|
|
|
}
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
void static destruct_uv_ares(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
|
|
|
{
|
|
|
|
int base_id = -1;
|
|
|
|
php_uv_ares_t *obj = (php_uv_ares_t *)rsrc->ptr;
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("# will be free: (resource_id: %d)", obj->resource_id);
|
2012-06-03 18:23:03 +02:00
|
|
|
|
|
|
|
if (obj->gethostbyname_cb) {
|
|
|
|
//fprintf(stderr, "udp_send_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
|
|
|
zval_ptr_dtor(&obj->gethostbyname_cb);
|
|
|
|
obj->gethostbyname_cb = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (obj != NULL) {
|
|
|
|
efree(obj);
|
|
|
|
obj = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (base_id) {
|
|
|
|
//fprintf(stderr,"resource_refcount:%d\n",rsrc->refcount);
|
|
|
|
zend_list_delete(base_id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-05-23 06:35:28 +02:00
|
|
|
void static destruct_uv(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
|
|
|
{
|
2012-05-27 08:36:03 +02:00
|
|
|
int base_id = -1;
|
2012-05-23 06:35:28 +02:00
|
|
|
php_uv_t *obj = (php_uv_t *)rsrc->ptr;
|
2012-06-01 18:37:29 +02:00
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("# will be free: (resource_id: %d)", obj->resource_id);
|
|
|
|
|
2012-05-27 16:27:17 +02:00
|
|
|
|
2012-05-27 08:36:03 +02:00
|
|
|
obj->in_free = 1;
|
2012-05-28 18:12:09 +02:00
|
|
|
if (obj->address) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "address: %d\n", Z_REFCOUNT_P(obj->read_cb));
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&obj->address);
|
|
|
|
obj->address = NULL;
|
|
|
|
}
|
2012-05-27 07:43:27 +02:00
|
|
|
if (obj->read_cb) {
|
2012-05-27 11:17:06 +02:00
|
|
|
//fprintf(stderr, "readcb: %d\n", Z_REFCOUNT_P(obj->read_cb));
|
2012-05-27 07:43:27 +02:00
|
|
|
zval_ptr_dtor(&obj->read_cb);
|
|
|
|
obj->read_cb = NULL;
|
|
|
|
}
|
2012-07-01 01:25:16 +02:00
|
|
|
if (obj->read2_cb) {
|
|
|
|
zval_ptr_dtor(&obj->read2_cb);
|
|
|
|
obj->read2_cb = NULL;
|
|
|
|
}
|
2012-05-27 07:43:27 +02:00
|
|
|
if (obj->write_cb) {
|
2012-05-27 11:17:06 +02:00
|
|
|
//fprintf(stderr, "writecb: %d\n", Z_REFCOUNT_P(obj->write_cb));
|
2012-05-27 07:43:27 +02:00
|
|
|
zval_ptr_dtor(&obj->write_cb);
|
|
|
|
obj->write_cb = NULL;
|
|
|
|
}
|
2012-06-30 18:55:48 +02:00
|
|
|
if (obj->shutdown_cb) {
|
|
|
|
//fprintf(stderr, "closecb: %d\n", Z_REFCOUNT_P(obj->close_cb));
|
|
|
|
zval_ptr_dtor(&obj->shutdown_cb);
|
|
|
|
obj->shutdown_cb = NULL;
|
|
|
|
}
|
2012-05-27 07:43:27 +02:00
|
|
|
if (obj->close_cb) {
|
2012-05-27 11:17:06 +02:00
|
|
|
//fprintf(stderr, "closecb: %d\n", Z_REFCOUNT_P(obj->close_cb));
|
2012-05-27 07:43:27 +02:00
|
|
|
zval_ptr_dtor(&obj->close_cb);
|
|
|
|
obj->close_cb = NULL;
|
|
|
|
}
|
|
|
|
if (obj->listen_cb) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "listen_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
2012-05-27 07:43:27 +02:00
|
|
|
zval_ptr_dtor(&obj->listen_cb);
|
|
|
|
obj->listen_cb = NULL;
|
|
|
|
}
|
2012-05-28 05:29:15 +02:00
|
|
|
if (obj->idle_cb) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "idle_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
2012-05-28 05:29:15 +02:00
|
|
|
zval_ptr_dtor(&obj->idle_cb);
|
|
|
|
obj->idle_cb = NULL;
|
|
|
|
}
|
2012-05-28 18:12:09 +02:00
|
|
|
if (obj->connect_cb) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "connect_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&obj->connect_cb);
|
|
|
|
obj->connect_cb = NULL;
|
|
|
|
}
|
2012-05-29 18:47:30 +02:00
|
|
|
if (obj->udp_recv_cb) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "udp_recv_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
2012-05-29 18:47:30 +02:00
|
|
|
zval_ptr_dtor(&obj->udp_recv_cb);
|
|
|
|
obj->udp_recv_cb = NULL;
|
|
|
|
}
|
|
|
|
if (obj->udp_send_cb) {
|
2012-05-30 06:06:37 +02:00
|
|
|
//fprintf(stderr, "udp_send_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
2012-05-29 18:47:30 +02:00
|
|
|
zval_ptr_dtor(&obj->udp_send_cb);
|
|
|
|
obj->udp_send_cb = NULL;
|
|
|
|
}
|
2012-05-31 19:23:34 +02:00
|
|
|
if (obj->pipe_connect_cb) {
|
|
|
|
//fprintf(stderr, "udp_send_cb: %d\n", Z_REFCOUNT_P(obj->listen_cb));
|
|
|
|
zval_ptr_dtor(&obj->pipe_connect_cb);
|
|
|
|
obj->pipe_connect_cb = NULL;
|
|
|
|
}
|
2012-06-14 15:24:19 +02:00
|
|
|
if (obj->proc_close_cb) {
|
|
|
|
//fprintf(stderr, "uv_spawn: %d\n", Z_REFCOUNT_P(obj->proc_close_cb));
|
|
|
|
zval_ptr_dtor(&obj->proc_close_cb);
|
|
|
|
obj->proc_close_cb = NULL;
|
|
|
|
}
|
2012-06-17 15:50:18 +02:00
|
|
|
if (obj->prepare_cb) {
|
|
|
|
//fprintf(stderr, "uv_prepare: %d\n", Z_REFCOUNT_P(obj->prepare_cb));
|
|
|
|
zval_ptr_dtor(&obj->prepare_cb);
|
|
|
|
obj->prepare_cb = NULL;
|
|
|
|
}
|
2012-06-17 16:04:54 +02:00
|
|
|
if (obj->check_cb) {
|
|
|
|
//fprintf(stderr, "uv_prepare: %d\n", Z_REFCOUNT_P(obj->prepare_cb));
|
|
|
|
zval_ptr_dtor(&obj->check_cb);
|
|
|
|
obj->check_cb = NULL;
|
|
|
|
}
|
2012-06-17 16:18:33 +02:00
|
|
|
if (obj->async_cb) {
|
|
|
|
//fprintf(stderr, "uv_async: %d\n", Z_REFCOUNT_P(obj->async_cb));
|
|
|
|
zval_ptr_dtor(&obj->async_cb);
|
|
|
|
obj->async_cb = NULL;
|
|
|
|
}
|
2012-06-17 18:32:50 +02:00
|
|
|
if (obj->work_cb) {
|
|
|
|
//fprintf(stderr, "uv_async: %d\n", Z_REFCOUNT_P(obj->async_cb));
|
|
|
|
zval_ptr_dtor(&obj->work_cb);
|
|
|
|
obj->work_cb = NULL;
|
|
|
|
}
|
|
|
|
if (obj->after_work_cb) {
|
|
|
|
//fprintf(stderr, "uv_async: %d\n", Z_REFCOUNT_P(obj->async_cb));
|
|
|
|
zval_ptr_dtor(&obj->after_work_cb);
|
|
|
|
obj->after_work_cb = NULL;
|
|
|
|
}
|
2012-06-20 05:40:39 +02:00
|
|
|
if (obj->fs_cb) {
|
|
|
|
//fprintf(stderr, "uv_fs: %d\n", Z_REFCOUNT_P(obj->fs_cb));
|
|
|
|
zval_ptr_dtor(&obj->fs_cb);
|
|
|
|
obj->fs_cb = NULL;
|
|
|
|
}
|
2012-06-23 20:34:06 +02:00
|
|
|
if (obj->getaddr_cb) {
|
|
|
|
//fprintf(stderr, "uv_fs: %d\n", Z_REFCOUNT_P(obj->fs_cb));
|
|
|
|
zval_ptr_dtor(&obj->getaddr_cb);
|
|
|
|
obj->getaddr_cb = NULL;
|
|
|
|
}
|
2012-06-25 18:27:06 +02:00
|
|
|
if (obj->timer_cb) {
|
|
|
|
//fprintf(stderr, "uv_timer: %d\n", Z_REFCOUNT_P(obj->timer_cb));
|
|
|
|
zval_ptr_dtor(&obj->timer_cb);
|
|
|
|
obj->timer_cb = NULL;
|
|
|
|
}
|
2012-05-28 05:29:15 +02:00
|
|
|
|
2012-05-27 08:36:03 +02:00
|
|
|
if (obj->resource_id) {
|
|
|
|
base_id = obj->resource_id;
|
2012-05-30 15:32:11 +02:00
|
|
|
obj->resource_id = 0;
|
2012-05-27 08:36:03 +02:00
|
|
|
}
|
|
|
|
|
2012-05-27 11:17:06 +02:00
|
|
|
if (obj != NULL) {
|
2012-05-27 07:43:27 +02:00
|
|
|
efree(obj);
|
2012-05-27 08:36:03 +02:00
|
|
|
obj = NULL;
|
|
|
|
}
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* callback */
|
|
|
|
|
2012-05-30 15:18:50 +02:00
|
|
|
static int php_uv_do_callback(zval **retval_ptr, zval *callback, zval ***params, int param_count TSRMLS_DC)
|
2012-05-28 18:12:09 +02:00
|
|
|
{
|
|
|
|
zend_fcall_info fci;
|
|
|
|
zend_fcall_info_cache fcc;
|
|
|
|
char *is_callable_error = NULL;
|
2012-05-29 05:37:08 +02:00
|
|
|
int error;
|
2012-06-17 18:32:50 +02:00
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
if(zend_fcall_info_init(callback, 0, &fci, &fcc, NULL, &is_callable_error TSRMLS_CC) == SUCCESS) {
|
2012-05-28 18:12:09 +02:00
|
|
|
if (is_callable_error) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "to be a valid callback");
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
}
|
2012-05-29 05:37:08 +02:00
|
|
|
fci.retval_ptr_ptr = retval_ptr;
|
|
|
|
fci.params = params;
|
|
|
|
fci.param_count = param_count;
|
|
|
|
|
|
|
|
error = zend_call_function(&fci, &fcc TSRMLS_CC);
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_tcp_connect_cb(uv_connect_t *req, int status)
|
|
|
|
{
|
|
|
|
zval *retval_ptr, *stat, *client= NULL;
|
|
|
|
zval **params[2];
|
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
MAKE_STD_ZVAL(client);
|
|
|
|
ZVAL_RESOURCE(client, uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &stat;
|
|
|
|
params[1] = &client;
|
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->connect_cb, params, 2 TSRMLS_CC);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&client);
|
|
|
|
efree(req);
|
|
|
|
}
|
|
|
|
|
2012-06-14 17:18:05 +02:00
|
|
|
static void php_uv_process_close_cb(uv_process_t* process, int exit_status, int term_signal)
|
|
|
|
{
|
2012-06-14 15:24:19 +02:00
|
|
|
zval *retval_ptr, *signal, *stat, *proc= NULL;
|
|
|
|
zval **params[3];
|
|
|
|
php_uv_t *uv = (php_uv_t*)process->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, exit_status);
|
|
|
|
MAKE_STD_ZVAL(signal);
|
|
|
|
ZVAL_LONG(signal, term_signal);
|
|
|
|
MAKE_STD_ZVAL(proc);
|
|
|
|
ZVAL_RESOURCE(proc, uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &proc;
|
|
|
|
params[1] = &stat;
|
|
|
|
params[2] = &signal;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->proc_close_cb, params, 3 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&proc);
|
|
|
|
zval_ptr_dtor(&signal);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-01 18:37:29 +02:00
|
|
|
static void php_uv_pipe_connect_cb(uv_connect_t *req, int status)
|
2012-05-31 19:23:34 +02:00
|
|
|
{
|
|
|
|
zval *retval_ptr, *stat, *client= NULL;
|
|
|
|
zval **params[2];
|
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
MAKE_STD_ZVAL(client);
|
|
|
|
ZVAL_RESOURCE(client, uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &stat;
|
|
|
|
params[1] = &client;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->pipe_connect_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&client);
|
|
|
|
efree(req);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
static void php_uv_write_cb(uv_write_t* req, int status)
|
|
|
|
{
|
2012-06-18 15:32:15 +02:00
|
|
|
write_req_t* wr = (write_req_t*) req;
|
2012-05-28 18:12:09 +02:00
|
|
|
zval *retval_ptr, *stat, *client= NULL;
|
|
|
|
zval **params[2];
|
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_write_cb: status: %d\n", status);
|
2012-05-28 18:12:09 +02:00
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(client);
|
|
|
|
ZVAL_RESOURCE(client, uv->resource_id);
|
2012-06-10 15:38:18 +02:00
|
|
|
//zend_list_addref(uv->resource_id);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
params[0] = &stat;
|
|
|
|
params[1] = &client;
|
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->write_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&client);
|
|
|
|
|
|
|
|
if (wr->buf.base) {
|
|
|
|
//free(wr->buf.base);
|
|
|
|
}
|
|
|
|
efree(wr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_write_cb, uv->resource_id);
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
static void php_uv_udp_send_cb(uv_udp_send_t* req, int status)
|
|
|
|
{
|
2012-06-18 15:32:15 +02:00
|
|
|
|
|
|
|
send_req_t* wr = (send_req_t*) req;
|
2012-05-29 18:47:30 +02:00
|
|
|
zval *retval_ptr, *stat, *client= NULL;
|
|
|
|
zval **params[2];
|
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
MAKE_STD_ZVAL(client);
|
|
|
|
ZVAL_RESOURCE(client, uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &stat;
|
|
|
|
params[1] = &client;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->udp_send_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&client);
|
|
|
|
|
|
|
|
if (wr->buf.base) {
|
|
|
|
efree(wr->buf.base);
|
|
|
|
}
|
|
|
|
efree(wr);
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
static void php_uv_listen_cb(uv_stream_t* server, int status)
|
|
|
|
{
|
|
|
|
zval *retval_ptr, *svr= NULL;
|
|
|
|
zval **params[1];
|
|
|
|
php_uv_t *uv = (php_uv_t*)server->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
MAKE_STD_ZVAL(svr);
|
|
|
|
ZVAL_RESOURCE(svr, uv->resource_id);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &svr;
|
2012-05-29 05:37:08 +02:00
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->listen_cb, params, 1 TSRMLS_CC);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&svr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_close_cb2(uv_handle_t *handle)
|
|
|
|
{
|
2012-06-11 06:14:15 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_close_cb2:\n");
|
|
|
|
|
2012-06-11 06:14:15 +02:00
|
|
|
zend_list_delete(uv->resource_id);
|
2012-06-30 15:15:29 +02:00
|
|
|
|
|
|
|
// maybe we can't call efree at here.
|
|
|
|
//efree(handle);
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
static void php_uv_shutdown_cb(uv_shutdown_t* handle, int status)
|
2012-05-28 18:12:09 +02:00
|
|
|
{
|
2012-06-30 18:55:48 +02:00
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[1];
|
|
|
|
zval *h;
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(h);
|
|
|
|
ZVAL_RESOURCE(h, uv->resource_id);
|
|
|
|
|
|
|
|
if (uv->shutdown_cb != NULL) {
|
|
|
|
params[0] = &h;
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->shutdown_cb, params, 1 TSRMLS_CC);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_shutdown_cb, uv->resource_id);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&h);
|
|
|
|
efree(handle);
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_read_cb(uv_stream_t* handle, ssize_t nread, uv_buf_t buf)
|
|
|
|
{
|
2012-06-30 15:15:29 +02:00
|
|
|
zval *rsc, *buffer, *err, *retval_ptr = NULL;
|
|
|
|
zval **params[3];
|
2012-06-18 15:32:15 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_read_cb\n");
|
2012-06-10 15:38:18 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
if (nread < 0) {
|
2012-05-29 05:37:08 +02:00
|
|
|
/* does this should be in user-land ? */
|
2012-06-30 18:55:48 +02:00
|
|
|
//uv_shutdown_t* req;
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
/* Error or EOF */
|
2012-06-30 18:55:48 +02:00
|
|
|
//assert(uv_last_error(uv_default_loop()).code == UV_EOF);
|
|
|
|
//if (buf.base) {
|
|
|
|
// efree(buf.base);
|
|
|
|
//}
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
//req = (uv_shutdown_t*) emalloc(sizeof *req);
|
|
|
|
//PHP_UV_DEBUG_PRINT("uv_read_cb: read close\n");
|
2012-06-29 17:42:33 +02:00
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
//uv_shutdown(req, (uv_handle_t *)handle, php_uv_shutdown_cb);
|
|
|
|
//return;
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (nread == 0) {
|
|
|
|
/* Everything OK, but nothing read. */
|
2012-06-30 18:55:48 +02:00
|
|
|
//efree(buf.base);
|
|
|
|
//return;
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(buffer);
|
2012-06-30 18:55:48 +02:00
|
|
|
if (nread > 0) {
|
|
|
|
ZVAL_STRINGL(buffer,buf.base,nread, 1);
|
|
|
|
} else {
|
|
|
|
ZVAL_NULL(buffer);
|
|
|
|
}
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(rsc);
|
|
|
|
ZVAL_RESOURCE(rsc, uv->resource_id);
|
2012-07-01 02:08:23 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-06-30 15:15:29 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(err)
|
|
|
|
ZVAL_LONG(err, nread);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-06-30 15:15:29 +02:00
|
|
|
params[0] = &rsc;
|
|
|
|
params[1] = &buffer;
|
|
|
|
params[2] = &err;
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-06-30 15:15:29 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->read_cb, params, 3 TSRMLS_CC);
|
2012-05-29 05:37:08 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&buffer);
|
|
|
|
zval_ptr_dtor(&rsc);
|
2012-06-30 15:15:29 +02:00
|
|
|
zval_ptr_dtor(&err);
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
|
|
|
|
if (buf.base) {
|
|
|
|
efree(buf.base);
|
|
|
|
}
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_read_cb, uv->resource_id);
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
2012-07-01 01:25:16 +02:00
|
|
|
static void php_uv_read2_cb(uv_pipe_t* handle, ssize_t nread, uv_buf_t buf, uv_handle_type pending)
|
|
|
|
{
|
2012-07-01 01:42:50 +02:00
|
|
|
zval *rsc, *buffer, *err, *pend, *retval_ptr = NULL;
|
|
|
|
zval **params[4];
|
2012-07-01 01:25:16 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
PHP_UV_DEBUG_PRINT("uv_read2_cb\n");
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(buffer);
|
|
|
|
if (nread > 0) {
|
|
|
|
ZVAL_STRINGL(buffer,buf.base,nread, 1);
|
|
|
|
} else {
|
|
|
|
ZVAL_NULL(buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(rsc);
|
|
|
|
ZVAL_RESOURCE(rsc, uv->resource_id);
|
|
|
|
//zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(err)
|
|
|
|
ZVAL_LONG(err, nread);
|
2012-07-01 01:42:50 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(pend);
|
|
|
|
ZVAL_LONG(pend, pending);
|
2012-07-01 01:25:16 +02:00
|
|
|
|
|
|
|
params[0] = &rsc;
|
|
|
|
params[1] = &buffer;
|
|
|
|
params[2] = &err;
|
2012-07-01 01:42:50 +02:00
|
|
|
params[3] = &pend;
|
2012-07-01 01:25:16 +02:00
|
|
|
|
2012-07-01 01:42:50 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->read2_cb, params, 4 TSRMLS_CC);
|
2012-07-01 01:25:16 +02:00
|
|
|
|
|
|
|
zval_ptr_dtor(&buffer);
|
|
|
|
zval_ptr_dtor(&rsc);
|
|
|
|
zval_ptr_dtor(&err);
|
2012-07-01 01:42:50 +02:00
|
|
|
zval_ptr_dtor(&pend);
|
2012-07-01 01:25:16 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
|
|
|
|
if (buf.base) {
|
|
|
|
efree(buf.base);
|
|
|
|
}
|
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_read2_cb, uv->resource_id);
|
|
|
|
}
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
static void php_uv_prepare_cb(uv_prepare_t* handle, int status)
|
2012-06-17 15:50:18 +02:00
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[1];
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *zstat;
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("prepare_cb\n");
|
2012-06-17 15:50:18 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(zstat);
|
|
|
|
ZVAL_LONG(zstat, status);
|
|
|
|
|
|
|
|
params[0] = &zstat;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->prepare_cb, params, 1 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&zstat);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_prepare_cb, uv->resource_id);
|
2012-06-17 15:50:18 +02:00
|
|
|
}
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
static void php_uv_check_cb(uv_check_t* handle, int status)
|
2012-06-17 16:04:54 +02:00
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[1];
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *zstat;
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("check_cb\n");
|
2012-06-17 16:04:54 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(zstat);
|
|
|
|
ZVAL_LONG(zstat, status);
|
|
|
|
|
|
|
|
params[0] = &zstat;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->check_cb, params, 1 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&zstat);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_check_cb, uv->resource_id);
|
2012-06-17 16:04:54 +02:00
|
|
|
}
|
|
|
|
|
2012-06-17 15:50:18 +02:00
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
static void php_uv_async_cb(uv_async_t* handle, int status)
|
2012-06-17 16:18:33 +02:00
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[1];
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *zstat;
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("async_cb\n");
|
2012-06-17 16:18:33 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(zstat);
|
|
|
|
ZVAL_LONG(zstat, status);
|
|
|
|
|
|
|
|
params[0] = &zstat;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->async_cb, params, 1 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&zstat);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_async_cb, uv->resource_id);
|
2012-06-17 16:18:33 +02:00
|
|
|
}
|
|
|
|
|
2012-06-17 15:50:18 +02:00
|
|
|
|
2012-06-17 18:32:50 +02:00
|
|
|
static void php_uv_work_cb(uv_work_t* req)
|
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
2012-06-25 18:04:16 +02:00
|
|
|
php_uv_t *uv;
|
2012-06-30 07:54:58 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-06-26 18:12:28 +02:00
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
uv = (php_uv_t*)req->data;
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("work_cb\n");
|
2012-06-17 18:32:50 +02:00
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->work_cb, NULL, 0 TSRMLS_CC);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_work_cb, uv->resource_id);
|
2012-06-17 18:32:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_after_work_cb(uv_work_t* req)
|
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
2012-06-18 15:32:15 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("after_work_cb\n");
|
2012-06-17 18:32:50 +02:00
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->after_work_cb, NULL, 0 TSRMLS_CC);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_after_work_cb, uv->resource_id);
|
2012-06-17 18:32:50 +02:00
|
|
|
}
|
|
|
|
|
2012-06-20 05:40:39 +02:00
|
|
|
static void php_uv_fs_cb(uv_fs_t* req)
|
|
|
|
{
|
2012-06-22 01:20:22 +02:00
|
|
|
zval **params[2], *result, *retval_ptr = NULL;
|
2012-06-20 05:40:39 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
2012-06-22 01:20:22 +02:00
|
|
|
int argc = 2;
|
2012-06-20 05:40:39 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("vc_cb\n");
|
2012-06-20 05:40:39 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(result);
|
|
|
|
ZVAL_LONG(result, uv->uv.fs.result);
|
|
|
|
params[0] = &result;
|
|
|
|
|
2012-06-22 05:51:16 +02:00
|
|
|
switch (uv->uv.fs.fs_type) {
|
2012-06-22 19:17:41 +02:00
|
|
|
case UV_FS_SYMLINK:
|
|
|
|
case UV_FS_LINK:
|
2012-06-22 19:03:00 +02:00
|
|
|
case UV_FS_CHMOD:
|
|
|
|
case UV_FS_FCHMOD:
|
2012-06-22 18:48:29 +02:00
|
|
|
case UV_FS_RENAME:
|
2012-06-22 18:45:00 +02:00
|
|
|
case UV_FS_UNLINK:
|
|
|
|
case UV_FS_RMDIR:
|
|
|
|
case UV_FS_MKDIR:
|
2012-06-22 18:26:44 +02:00
|
|
|
case UV_FS_FTRUNCATE:
|
2012-06-22 18:19:21 +02:00
|
|
|
case UV_FS_FDATASYNC:
|
2012-06-22 17:59:27 +02:00
|
|
|
case UV_FS_FSYNC:
|
2012-06-22 17:53:58 +02:00
|
|
|
case UV_FS_CLOSE:
|
2012-06-22 19:07:56 +02:00
|
|
|
case UV_FS_CHOWN:
|
|
|
|
case UV_FS_FCHOWN:
|
2012-06-22 17:53:58 +02:00
|
|
|
argc = 1;
|
|
|
|
break;
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_OPEN:
|
|
|
|
{
|
2012-06-22 16:01:32 +02:00
|
|
|
argc = 1;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_READDIR:
|
|
|
|
{
|
|
|
|
zval *dirent;
|
|
|
|
int nnames, i = 0;
|
|
|
|
char *namebuf = (char *)req->ptr;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(dirent);
|
|
|
|
array_init(dirent);
|
|
|
|
|
|
|
|
nnames = req->result;
|
|
|
|
for (i = 0; i < nnames; i++) {
|
|
|
|
add_next_index_string(dirent, namebuf, 1);
|
|
|
|
namebuf += strlen(namebuf) + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
params[1] = &dirent;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-23 06:00:27 +02:00
|
|
|
case UV_FS_LSTAT:
|
|
|
|
case UV_FS_FSTAT:
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_STAT:
|
|
|
|
{
|
2012-06-23 05:01:10 +02:00
|
|
|
zval *buffer;
|
2012-06-23 06:00:27 +02:00
|
|
|
buffer = php_uv_make_stat((const uv_statbuf_t*)req->ptr);
|
2012-06-23 05:01:10 +02:00
|
|
|
params[1] = &buffer;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-22 18:58:00 +02:00
|
|
|
case UV_FS_UTIME:
|
|
|
|
case UV_FS_FUTIME:
|
|
|
|
argc = 0;
|
|
|
|
break;
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_READLINK:
|
|
|
|
{
|
2012-06-23 04:22:41 +02:00
|
|
|
zval *buffer;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(buffer);
|
|
|
|
ZVAL_STRING(buffer, req->ptr, 1);
|
|
|
|
params[1] = &buffer;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_READ:
|
|
|
|
{
|
2012-06-22 05:51:16 +02:00
|
|
|
zval *buffer;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(buffer);
|
2012-06-22 16:01:32 +02:00
|
|
|
if (uv->uv.fs.result > 0) {
|
|
|
|
ZVAL_STRINGL(buffer, uv_fs_read_buf, uv->uv.fs.result, 1);
|
|
|
|
} else {
|
|
|
|
ZVAL_NULL(buffer);
|
|
|
|
}
|
2012-06-22 05:51:16 +02:00
|
|
|
params[1] = &buffer;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-23 06:40:12 +02:00
|
|
|
case UV_FS_SENDFILE:
|
|
|
|
{
|
|
|
|
zval *res;
|
2012-06-25 16:59:49 +02:00
|
|
|
argc = 2;
|
2012-06-23 06:40:12 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(res);
|
|
|
|
ZVAL_LONG(res, uv->uv.fs.result);
|
|
|
|
|
|
|
|
params[1] = &res;
|
|
|
|
break;
|
|
|
|
}
|
2012-06-23 06:27:59 +02:00
|
|
|
case UV_FS_WRITE:
|
|
|
|
{
|
2012-06-23 06:40:12 +02:00
|
|
|
zval *res;
|
2012-06-25 16:59:49 +02:00
|
|
|
argc = 1;
|
2012-06-23 06:40:12 +02:00
|
|
|
MAKE_STD_ZVAL(res);
|
|
|
|
ZVAL_LONG(res, uv->uv.fs.result);
|
|
|
|
|
|
|
|
params[1] = &res;
|
2012-06-22 05:51:16 +02:00
|
|
|
efree(uv->buffer);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default: {
|
|
|
|
fprintf(stderr,"type; %d does not support yet.", uv->uv.fs.fs_type);
|
|
|
|
break;
|
|
|
|
}
|
2012-06-22 01:20:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->fs_cb, params, argc TSRMLS_CC);
|
|
|
|
|
|
|
|
if (argc == 2) {
|
|
|
|
zval_ptr_dtor(params[1]);
|
|
|
|
}
|
|
|
|
|
2012-06-20 05:40:39 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&result);
|
2012-06-22 01:20:22 +02:00
|
|
|
uv_fs_req_cleanup(req);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_fs_cb, uv->resource_id);
|
2012-06-20 05:40:39 +02:00
|
|
|
}
|
|
|
|
|
2012-06-23 07:18:38 +02:00
|
|
|
static void php_uv_fs_event_cb(uv_fs_event_t* req, const char* filename, int events, int status)
|
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
php_uv_t *uv = (php_uv_t*)req->data;
|
|
|
|
zval **params[3];
|
|
|
|
zval *name,*ev,*stat;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("fs_event_cb: %s, %d\n", filename, status);
|
2012-06-23 07:18:38 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(name);
|
|
|
|
MAKE_STD_ZVAL(ev);
|
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
if (filename) {
|
|
|
|
ZVAL_STRING(name,filename,1);
|
|
|
|
} else {
|
|
|
|
ZVAL_NULL(name);
|
|
|
|
}
|
|
|
|
ZVAL_LONG(ev, events);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
|
|
|
|
params[0] = &name;
|
|
|
|
params[1] = &ev;
|
|
|
|
params[2] = &stat;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->fs_event_cb, params, 3 TSRMLS_CC);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(params[0]);
|
|
|
|
zval_ptr_dtor(params[1]);
|
|
|
|
zval_ptr_dtor(params[2]);
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_fs_event_cb, uv->resource_id);
|
2012-06-23 07:18:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
static void php_uv_udp_recv_cb(uv_udp_t* handle, ssize_t nread, uv_buf_t buf, struct sockaddr* addr, unsigned flags)
|
2012-05-29 18:47:30 +02:00
|
|
|
{
|
2012-05-30 06:07:37 +02:00
|
|
|
/* TODO: is this implment correct? */
|
2012-05-29 18:47:30 +02:00
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[2];
|
|
|
|
zval *buffer;
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *rsc;
|
2012-06-14 17:18:05 +02:00
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
if (nread < 0) {
|
|
|
|
/* does this should be in user-land ? */
|
2012-06-30 18:55:48 +02:00
|
|
|
//uv_shutdown_t* req;
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
/* Error or EOF */
|
2012-06-30 18:55:48 +02:00
|
|
|
///assert(uv_last_error(uv_default_loop()).code == UV_EOF);
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
if (buf.base) {
|
2012-06-30 18:55:48 +02:00
|
|
|
//efree(buf.base);
|
2012-05-29 18:47:30 +02:00
|
|
|
}
|
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
//req = (uv_shutdown_t*) emalloc(sizeof *req);
|
|
|
|
//uv_shutdown(req, (uv_stream_t*)handle, php_uv_shutdown_cb);
|
|
|
|
//return;
|
2012-05-29 18:47:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (nread == 0) {
|
|
|
|
/* Everything OK, but nothing read. */
|
|
|
|
efree(buf.base);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(buffer);
|
|
|
|
ZVAL_STRINGL(buffer,buf.base,nread, 1);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(rsc);
|
|
|
|
ZVAL_RESOURCE(rsc, uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &buffer;
|
|
|
|
params[1] = &rsc;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->udp_recv_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&buffer);
|
|
|
|
zval_ptr_dtor(&rsc);
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
|
|
|
|
if (buf.base) {
|
|
|
|
efree(buf.base);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
static uv_buf_t php_uv_read_alloc(uv_handle_t* handle, size_t suggested_size)
|
|
|
|
{
|
|
|
|
return uv_buf_init(emalloc(suggested_size), suggested_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void php_uv_close_cb(uv_handle_t *handle)
|
|
|
|
{
|
|
|
|
zval *retval_ptr = NULL;
|
|
|
|
zval **params[1];
|
|
|
|
zval *h;
|
|
|
|
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-06-01 18:37:29 +02:00
|
|
|
MAKE_STD_ZVAL(h);
|
|
|
|
ZVAL_RESOURCE(h, uv->resource_id);
|
|
|
|
|
2012-05-29 01:00:17 +02:00
|
|
|
if (uv->close_cb != NULL) {
|
|
|
|
params[0] = &h;
|
2012-05-29 05:37:08 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->close_cb, params, 1 TSRMLS_CC);
|
2012-05-29 01:00:17 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
2012-06-01 18:37:29 +02:00
|
|
|
}
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_close_cb, uv->resource_id);
|
2012-07-01 02:08:23 +02:00
|
|
|
zend_hash_index_del(&EG(regular_list), uv->resource_id);
|
2012-06-29 17:58:20 +02:00
|
|
|
|
2012-06-12 05:08:55 +02:00
|
|
|
zval_ptr_dtor(&h); /* call destruct_uv */
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void php_uv_idle_cb(uv_timer_t *handle, int status)
|
|
|
|
{
|
|
|
|
zval *retval_ptr, *stat = NULL;
|
|
|
|
zval **params[1];
|
|
|
|
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
params[0] = &stat;
|
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->idle_cb, params, 1 TSRMLS_CC);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_getaddrinfo_cb(uv_getaddrinfo_t* handle, int status, struct addrinfo* res)
|
|
|
|
{
|
2012-06-23 20:34:06 +02:00
|
|
|
zval *tmp, *retval_ptr, *stat = NULL;
|
|
|
|
zval **params[2];
|
2012-06-29 17:58:20 +02:00
|
|
|
struct addrinfo *address;
|
2012-06-23 20:34:06 +02:00
|
|
|
char ip[INET6_ADDRSTRLEN];
|
|
|
|
const char *addr;
|
|
|
|
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
params[0] = &stat;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
array_init(tmp);
|
|
|
|
|
|
|
|
address = res;
|
|
|
|
while (address) {
|
|
|
|
if (address->ai_family == AF_INET) {
|
2012-06-25 16:59:49 +02:00
|
|
|
const char *c;
|
|
|
|
|
2012-06-23 20:34:06 +02:00
|
|
|
addr = (char*) &((struct sockaddr_in*) address->ai_addr)->sin_addr;
|
2012-06-25 16:59:49 +02:00
|
|
|
c = uv_inet_ntop(address->ai_family, addr, ip, INET6_ADDRSTRLEN);
|
2012-06-23 20:34:06 +02:00
|
|
|
add_next_index_string(tmp, c, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
address = address->ai_next;
|
|
|
|
}
|
|
|
|
|
|
|
|
address = res;
|
|
|
|
while (address) {
|
|
|
|
if (address->ai_family == AF_INET6) {
|
2012-06-25 16:59:49 +02:00
|
|
|
const char *c;
|
|
|
|
|
2012-06-23 20:34:06 +02:00
|
|
|
addr = (char*) &((struct sockaddr_in6*) address->ai_addr)->sin6_addr;
|
2012-06-25 16:59:49 +02:00
|
|
|
c = uv_inet_ntop(address->ai_family, addr, ip, INET6_ADDRSTRLEN);
|
2012-06-23 20:34:06 +02:00
|
|
|
add_next_index_string(tmp, c, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
address = address->ai_next;
|
|
|
|
}
|
|
|
|
|
|
|
|
params[1] = &tmp;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->getaddr_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&tmp);
|
|
|
|
|
|
|
|
zend_list_delete(uv->resource_id);
|
2012-05-28 18:12:09 +02:00
|
|
|
uv_freeaddrinfo(res);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void php_uv_timer_cb(uv_timer_t *handle, int status)
|
|
|
|
{
|
|
|
|
zval *retval_ptr, *stat, *client= NULL;
|
|
|
|
zval **params[2];
|
|
|
|
php_uv_t *uv = (php_uv_t*)handle->data;
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_FETCH_FROM_CTX(uv->thread_ctx);
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
MAKE_STD_ZVAL(stat);
|
|
|
|
ZVAL_LONG(stat, status);
|
|
|
|
MAKE_STD_ZVAL(client);
|
|
|
|
ZVAL_RESOURCE(client, uv->resource_id);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
params[0] = &stat;
|
|
|
|
params[1] = &client;
|
|
|
|
|
2012-05-29 05:37:08 +02:00
|
|
|
php_uv_do_callback(&retval_ptr, uv->timer_cb, params, 2 TSRMLS_CC);
|
2012-05-27 08:36:03 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&stat);
|
|
|
|
zval_ptr_dtor(&client);
|
2012-05-23 06:35:28 +02:00
|
|
|
}
|
|
|
|
|
2012-05-30 23:59:21 +02:00
|
|
|
static inline uv_stream_t* php_uv_get_current_stream(php_uv_t *uv)
|
|
|
|
{
|
|
|
|
uv_stream_t *stream;
|
|
|
|
switch(uv->type) {
|
|
|
|
case IS_UV_TCP:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.tcp;
|
|
|
|
break;
|
|
|
|
case IS_UV_UDP:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.udp;
|
|
|
|
break;
|
|
|
|
case IS_UV_PIPE:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.pipe;
|
|
|
|
break;
|
|
|
|
case IS_UV_IDLE:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.idle;
|
|
|
|
break;
|
|
|
|
case IS_UV_TIMER:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.timer;
|
|
|
|
break;
|
|
|
|
case IS_UV_ASYNC:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.async;
|
|
|
|
break;
|
|
|
|
case IS_UV_LOOP:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.loop;
|
|
|
|
break;
|
|
|
|
case IS_UV_HANDLE:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.handle;
|
|
|
|
break;
|
|
|
|
case IS_UV_STREAM:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.stream;
|
|
|
|
break;
|
2012-06-14 15:24:19 +02:00
|
|
|
case IS_UV_PROCESS:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.process;
|
|
|
|
break;
|
2012-06-17 15:50:18 +02:00
|
|
|
case IS_UV_PREPARE:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.prepare;
|
|
|
|
break;
|
2012-06-17 16:04:54 +02:00
|
|
|
case IS_UV_CHECK:
|
|
|
|
stream = (uv_stream_t*)&uv->uv.check;
|
|
|
|
break;
|
2012-06-14 17:18:05 +02:00
|
|
|
default: {
|
|
|
|
TSRMLS_FETCH();
|
2012-06-14 16:07:12 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "unexpected type found");
|
2012-06-14 15:24:19 +02:00
|
|
|
break;
|
2012-06-14 17:18:05 +02:00
|
|
|
}
|
2012-05-30 23:59:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return stream;
|
|
|
|
}
|
|
|
|
|
2012-07-01 06:15:14 +02:00
|
|
|
void static destruct_httpparser(zend_rsrc_list_entry *rsrc TSRMLS_DC)
|
|
|
|
{
|
|
|
|
http_parser *obj = (http_parser *)rsrc->ptr;
|
|
|
|
|
|
|
|
efree(obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* http parser callbacks */
|
|
|
|
int on_message_begin(http_parser *p)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int on_headers_complete(http_parser *p)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int on_message_complete(http_parser *p)
|
|
|
|
{
|
|
|
|
php_http_parser_context *result = p->data;
|
|
|
|
result->finished = 1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define PHP_HTTP_PARSER_PARSE_URL(flag, name) \
|
|
|
|
if (result->handle.field_set & (1 << flag)) { \
|
|
|
|
const char *name = at+result->handle.field_data[flag].off; \
|
|
|
|
int length = result->handle.field_data[flag].len; \
|
|
|
|
add_assoc_stringl(data, #name, (char*)name, length, 1); \
|
|
|
|
}
|
|
|
|
|
|
|
|
int on_url_cb(http_parser *p, const char *at, size_t len)
|
|
|
|
{
|
|
|
|
php_http_parser_context *result = p->data;
|
|
|
|
zval *data = result->data;
|
|
|
|
|
|
|
|
http_parser_parse_url(at, len, 0, &result->handle);
|
|
|
|
|
|
|
|
add_assoc_stringl(data, "QUERY_STRING", (char*)at, len, 1);
|
|
|
|
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_SCHEMA, scheme);
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_HOST, host);
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_PORT, port);
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_PATH, path);
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_QUERY, query);
|
|
|
|
PHP_HTTP_PARSER_PARSE_URL(UF_FRAGMENT, fragment);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int header_field_cb(http_parser *p, const char *at, size_t len)
|
|
|
|
{
|
|
|
|
php_http_parser_context *result = p->data;
|
|
|
|
/* TODO: */
|
|
|
|
result->tmp = estrndup(at, len);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int header_value_cb(http_parser *p, const char *at, size_t len)
|
|
|
|
{
|
|
|
|
php_http_parser_context *result = p->data;
|
|
|
|
zval *data = result->headers;
|
|
|
|
|
|
|
|
add_assoc_stringl(data, result->tmp, (char*)at, len, 1);
|
|
|
|
/* TODO: */
|
|
|
|
efree(result->tmp);
|
|
|
|
result->tmp = NULL;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int on_body_cb(http_parser *p, const char *at, size_t len)
|
|
|
|
{
|
|
|
|
php_http_parser_context *result = p->data;
|
|
|
|
zval *data = result->headers;
|
|
|
|
|
|
|
|
add_assoc_stringl(data, "body", (char*)at, len, 1);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/* end of callback */
|
|
|
|
|
2012-05-30 23:59:21 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
/* zend */
|
2012-05-22 19:43:11 +02:00
|
|
|
|
|
|
|
PHP_MINIT_FUNCTION(uv) {
|
2012-06-03 17:10:30 +02:00
|
|
|
int rc;
|
|
|
|
|
2012-05-22 19:43:11 +02:00
|
|
|
php_uv_init(TSRMLS_C);
|
2012-05-23 06:35:28 +02:00
|
|
|
uv_resource_handle = zend_register_list_destructors_ex(destruct_uv, NULL, PHP_UV_RESOURCE_NAME, module_number);
|
2012-06-28 15:49:08 +02:00
|
|
|
uv_ares_handle = zend_register_list_destructors_ex(destruct_uv_ares, NULL, PHP_UV_ARES_RESOURCE_NAME, module_number);
|
|
|
|
uv_loop_handle = zend_register_list_destructors_ex(destruct_uv_loop, NULL, PHP_UV_LOOP_RESOURCE_NAME, module_number);
|
2012-05-28 18:12:09 +02:00
|
|
|
uv_sockaddr_handle = zend_register_list_destructors_ex(destruct_uv_sockaddr, NULL, PHP_UV_SOCKADDR_RESOURCE_NAME, module_number);
|
2012-06-30 07:10:58 +02:00
|
|
|
uv_lock_handle = zend_register_list_destructors_ex(destruct_uv_lock, NULL, PHP_UV_LOCK_RESOURCE_NAME, module_number);
|
2012-07-01 06:15:14 +02:00
|
|
|
uv_httpparser_handle = zend_register_list_destructors_ex(destruct_httpparser, NULL, PHP_UV_HTTPPARSER_RESOURCE_NAME, module_number);
|
2012-05-22 19:43:11 +02:00
|
|
|
|
2012-06-03 17:10:30 +02:00
|
|
|
rc = ares_library_init(ARES_LIB_INIT_ALL);
|
|
|
|
if (rc != 0) {
|
|
|
|
printf("ares library init fails %d\n", rc);
|
2012-06-04 05:40:50 +02:00
|
|
|
return FAILURE;
|
2012-06-03 17:10:30 +02:00
|
|
|
}
|
|
|
|
|
2012-05-22 19:43:11 +02:00
|
|
|
return SUCCESS;
|
|
|
|
}
|
|
|
|
|
2012-05-28 15:18:36 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_run_once, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 06:35:28 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_run, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-30 23:36:11 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_loop_delete, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-30 23:39:58 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_now, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 06:35:28 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_connect, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-24 09:28:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_connect6, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 13:41:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_init, 0, 0, 0)
|
2012-05-23 06:35:28 +02:00
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 13:41:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_listen, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, backlog)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 19:31:16 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_accept, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, client)
|
|
|
|
ZEND_END_ARG_INFO()
|
2012-05-23 13:41:04 +02:00
|
|
|
|
2012-05-24 06:07:52 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_read_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-07-01 01:25:16 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_read2_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-30 23:43:12 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_read_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-26 10:29:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_write, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, client)
|
|
|
|
ZEND_ARG_INFO(0, data)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-26 15:54:43 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_last_error, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-29 01:00:17 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_strerror, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, error)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-30 06:17:01 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_err_name, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, error)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-26 16:26:29 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 05:37:56 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_idle_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, idle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-31 00:11:52 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_again, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, idle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-26 16:26:29 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_start, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_ARG_INFO(0, timeout)
|
|
|
|
ZEND_ARG_INFO(0, repeat)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-31 00:11:52 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_again, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_set_repeat, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_ARG_INFO(0, timeout)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_timer_get_repeat, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 05:29:15 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_idle_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, timer)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-23 13:41:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_bind, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
2012-06-24 09:28:04 +02:00
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_bind6, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
2012-05-23 13:41:04 +02:00
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_shutdown, 0, 0, 2)
|
2012-05-26 15:54:43 +02:00
|
|
|
ZEND_ARG_INFO(0, stream)
|
2012-06-30 18:55:48 +02:00
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_close, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, stream)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
2012-05-26 15:54:43 +02:00
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 05:29:15 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_idle_init, 0, 0, 0)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-30 06:13:10 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_update_time, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
2012-05-30 23:59:21 +02:00
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_is_active, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_is_readable, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_is_writable, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 15:24:10 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ref, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_unref, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 15:54:54 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_nodelay, 0, 0, 2)
|
2012-05-28 15:44:54 +02:00
|
|
|
ZEND_ARG_INFO(0, tcp)
|
2012-05-28 15:54:54 +02:00
|
|
|
ZEND_ARG_INFO(0, enabled)
|
2012-05-28 15:44:54 +02:00
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ip4_addr, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
|
|
|
ZEND_ARG_INFO(0, port)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-24 08:18:33 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ip6_addr, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
|
|
|
ZEND_ARG_INFO(0, port)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_bind, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
|
|
|
ZEND_ARG_INFO(0, flags)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-24 09:28:04 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_bind6, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
|
|
|
ZEND_ARG_INFO(0, flags)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_recv_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_recv_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_set_multicast_loop, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, enabled)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_set_multicast_ttl, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, ttl)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_set_broadcast, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, enabled)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_send, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, server)
|
|
|
|
ZEND_ARG_INFO(0, buffer)
|
|
|
|
ZEND_ARG_INFO(0, address)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_pipe_open, 0, 0, 2)
|
2012-05-31 06:39:30 +02:00
|
|
|
ZEND_ARG_INFO(0, file)
|
2012-05-31 19:23:34 +02:00
|
|
|
ZEND_ARG_INFO(0, pipe)
|
2012-05-31 06:39:30 +02:00
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_pipe_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, file)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_pipe_bind, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, name)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_pipe_connect, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, name)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
2012-05-31 06:39:30 +02:00
|
|
|
|
2012-06-02 08:29:31 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_pipe_pending_instances, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, count)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-16 09:19:17 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_spawn, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, command)
|
|
|
|
ZEND_ARG_INFO(0, args)
|
|
|
|
ZEND_ARG_INFO(0, options)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
|
2012-06-16 09:17:52 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_kill, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, pid)
|
|
|
|
ZEND_ARG_INFO(0, signal)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_process_kill, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, process)
|
|
|
|
ZEND_ARG_INFO(0, signal)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-16 09:48:13 +02:00
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_chdir, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, dir)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-23 08:05:14 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tty_get_winsize, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, tty)
|
|
|
|
ZEND_ARG_INFO(1, width)
|
|
|
|
ZEND_ARG_INFO(1, height)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-26 18:03:34 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tty_init, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, readable)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_event_init, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_ARG_INFO(0, flags)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_sendfile, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, in)
|
|
|
|
ZEND_ARG_INFO(0, out)
|
|
|
|
ZEND_ARG_INFO(0, offset)
|
|
|
|
ZEND_ARG_INFO(0, length)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_readdir, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, flags)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_fstat, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_lstat, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_stat, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_readlink, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_symlink, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, from)
|
|
|
|
ZEND_ARG_INFO(0, to)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_ARG_INFO(0, flags)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_link, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, from)
|
|
|
|
ZEND_ARG_INFO(0, to)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_fchown, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, uid)
|
|
|
|
ZEND_ARG_INFO(0, gid)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_chown, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, uid)
|
|
|
|
ZEND_ARG_INFO(0, gid)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_fchmod, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, mode)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_chmod, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, mode)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_futime, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, utime)
|
|
|
|
ZEND_ARG_INFO(0, atime)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_utime, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, utime)
|
|
|
|
ZEND_ARG_INFO(0, atime)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_open, 0, 0, 5)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, flag)
|
|
|
|
ZEND_ARG_INFO(0, mode)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_read, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_close, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_write, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, buffer)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_fsync, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_fdatasync, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_ftruncate, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, fd)
|
|
|
|
ZEND_ARG_INFO(0, offset)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_mkdir, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, mode)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_rmdir, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_unlink, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, path)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_fs_rename, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, from)
|
|
|
|
ZEND_ARG_INFO(0, to)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
2012-06-23 08:05:14 +02:00
|
|
|
|
2012-06-26 18:32:56 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_rdlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_tryrdlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_rdunlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_wrlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_trywrlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_rwlock_wrunlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_mutex_lock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_mutex_trylock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_mutex_unlock, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_prepare_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_prepare_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_prepare_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_check_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_check_start, 0, 0, 2)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_check_stop, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_async_send, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_async_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-06-28 15:33:10 +02:00
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_ares_gethostbyname, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_ARG_INFO(0, name)
|
|
|
|
ZEND_ARG_INFO(0, callback)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ares_init_options, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, loop)
|
|
|
|
ZEND_ARG_INFO(0, options)
|
|
|
|
ZEND_ARG_INFO(0, mask)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_getsockname, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_tcp_getpeername, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_getsockname, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_udp_set_membership, 0, 0, 4)
|
|
|
|
ZEND_ARG_INFO(0, client)
|
|
|
|
ZEND_ARG_INFO(0, multicast_addr)
|
|
|
|
ZEND_ARG_INFO(0, interface_addr)
|
|
|
|
ZEND_ARG_INFO(0, membership)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ip6_name, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_ip4_name, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, handle)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
/* PHP Functions */
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 15:24:10 +02:00
|
|
|
PHP_FUNCTION(uv_unref)
|
|
|
|
{
|
2012-06-25 18:04:16 +02:00
|
|
|
zval *handle = NULL;
|
|
|
|
php_uv_t *uv;
|
2012-05-28 15:24:10 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-25 18:04:16 +02:00
|
|
|
"z",&handle) == FAILURE) {
|
2012-05-28 15:24:10 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-25 18:04:16 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
uv_unref((uv_handle_t *)php_uv_get_current_stream(uv));
|
2012-06-25 18:27:06 +02:00
|
|
|
zend_list_delete(uv->resource_id);
|
2012-05-28 15:24:10 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 15:24:10 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_last_error)
|
|
|
|
{
|
|
|
|
uv_loop_t *loop;
|
|
|
|
uv_err_t err;
|
|
|
|
zval *z_loop = NULL;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
err = uv_last_error(loop);
|
|
|
|
|
|
|
|
RETVAL_LONG(err.code);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 15:24:10 +02:00
|
|
|
|
2012-05-30 06:17:01 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_err_name)
|
|
|
|
{
|
|
|
|
long error_code;
|
2012-05-30 15:32:11 +02:00
|
|
|
const char *error_msg;
|
2012-05-30 06:17:01 +02:00
|
|
|
uv_err_t error;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"l",&error_code) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
error.code = error_code;
|
|
|
|
|
|
|
|
error_msg = uv_err_name(error);
|
|
|
|
RETVAL_STRING(error_msg,1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-05-29 01:00:17 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_strerror)
|
|
|
|
{
|
2012-05-30 06:09:47 +02:00
|
|
|
long error_code;
|
2012-05-30 15:32:11 +02:00
|
|
|
const char *error_msg;
|
2012-05-30 06:09:47 +02:00
|
|
|
uv_err_t error;
|
2012-05-29 01:00:17 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-30 06:09:47 +02:00
|
|
|
"l",&error_code) == FAILURE) {
|
2012-05-29 01:00:17 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-05-30 06:09:47 +02:00
|
|
|
error.code = error_code;
|
2012-05-29 01:00:17 +02:00
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
error_msg = uv_strerror(error);
|
2012-05-30 06:09:47 +02:00
|
|
|
RETVAL_STRING(error_msg,1);
|
2012-05-29 01:00:17 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-30 06:13:10 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_update_time)
|
|
|
|
{
|
|
|
|
zval *z_loop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_update_time(loop);
|
2012-05-30 06:13:10 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 15:24:10 +02:00
|
|
|
PHP_FUNCTION(uv_ref)
|
|
|
|
{
|
2012-06-25 18:04:16 +02:00
|
|
|
zval *handle = NULL;
|
|
|
|
php_uv_t *uv;
|
2012-05-28 15:24:10 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-25 18:04:16 +02:00
|
|
|
"z",&handle) == FAILURE) {
|
2012-05-28 15:24:10 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-25 18:04:16 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
uv_ref((uv_handle_t *)php_uv_get_current_stream(uv));
|
2012-06-25 18:27:06 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-28 15:24:10 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 15:24:10 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-23 06:35:28 +02:00
|
|
|
PHP_FUNCTION(uv_run)
|
|
|
|
{
|
2012-05-28 15:18:36 +02:00
|
|
|
zval *z_loop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (z_loop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = php_uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv_run(loop);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 15:18:36 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 15:18:36 +02:00
|
|
|
PHP_FUNCTION(uv_run_once)
|
|
|
|
{
|
|
|
|
zval *z_loop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (z_loop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = php_uv_default_loop();
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
uv_run_once(loop);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-05-30 23:36:11 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_loop_delete)
|
|
|
|
{
|
|
|
|
zval *z_loop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (z_loop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
uv_loop_delete(loop);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-30 23:39:58 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_now)
|
|
|
|
{
|
|
|
|
zval *z_loop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
int64_t now;
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&z_loop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (z_loop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
now = uv_now(loop);
|
|
|
|
RETURN_LONG((long)now);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-30 23:36:11 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_tcp_bind)
|
|
|
|
{
|
2012-06-02 14:45:43 +02:00
|
|
|
zval *resource, *address;
|
|
|
|
php_uv_sockaddr_t *addr;
|
2012-05-28 18:12:09 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
2012-05-27 15:28:26 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-02 14:45:43 +02:00
|
|
|
"zz",&resource, &address) == FAILURE) {
|
2012-05-27 15:28:26 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-02 14:45:43 +02:00
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
Z_ADDREF_P(resource);
|
2012-05-25 01:07:12 +02:00
|
|
|
|
2012-06-02 14:45:43 +02:00
|
|
|
r = uv_tcp_bind((uv_tcp_t*)&uv->uv.tcp, addr->addr.ipv4);
|
2012-05-28 18:12:09 +02:00
|
|
|
if (r) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "bind failed");
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-27 09:53:30 +02:00
|
|
|
|
2012-06-24 09:28:04 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tcp_bind6)
|
|
|
|
{
|
|
|
|
zval *resource, *address;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zz",&resource, &address) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
Z_ADDREF_P(resource);
|
|
|
|
|
|
|
|
r = uv_tcp_bind6((uv_tcp_t*)&uv->uv.tcp, addr->addr.ipv6);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "bind failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_write)
|
|
|
|
{
|
|
|
|
zval *z_cli,*callback;
|
|
|
|
char *data;
|
|
|
|
int data_len = 0;
|
2012-06-30 09:45:40 +02:00
|
|
|
php_uv_t *uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
write_req_t *w;
|
2012-07-01 13:09:19 +02:00
|
|
|
int r = 0;
|
2012-05-26 15:03:21 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz",&z_cli, &data, &data_len,&callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
2012-05-26 15:03:21 +02:00
|
|
|
|
2012-06-30 09:45:40 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &z_cli, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-28 18:12:09 +02:00
|
|
|
Z_ADDREF_P(callback);
|
2012-06-30 09:45:40 +02:00
|
|
|
uv->write_cb = callback;
|
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-27 16:13:09 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
w = emalloc(sizeof(write_req_t));
|
2012-06-30 09:45:40 +02:00
|
|
|
w->req.data = uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
w->buf = uv_buf_init(data, data_len);
|
2012-05-31 19:23:34 +02:00
|
|
|
|
2012-07-01 13:09:19 +02:00
|
|
|
r = uv_write(&w->req, (uv_stream_t*)php_uv_get_current_stream(uv), &w->buf, 1, php_uv_write_cb);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "write failed");
|
|
|
|
}
|
|
|
|
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_write, uv->resource_id);
|
2012-05-24 06:07:52 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-23 19:31:16 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_tcp_nodelay)
|
2012-05-24 16:29:54 +02:00
|
|
|
{
|
2012-05-28 18:12:09 +02:00
|
|
|
zval *z_cli;
|
|
|
|
php_uv_t *client;
|
|
|
|
long bval = 1;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zl",&z_cli, &bval) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(client, php_uv_t *, &z_cli, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_tcp_nodelay(&client->uv.tcp, bval);
|
2012-05-24 06:07:52 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-24 06:07:52 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_accept)
|
2012-05-26 15:54:43 +02:00
|
|
|
{
|
2012-05-28 18:12:09 +02:00
|
|
|
zval *z_svr,*z_cli;
|
|
|
|
php_uv_t *server, *client;
|
|
|
|
int r;
|
2012-05-26 15:54:43 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zz",&z_svr, &z_cli) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
2012-05-26 15:54:43 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
ZEND_FETCH_RESOURCE(server, php_uv_t *, &z_svr, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
ZEND_FETCH_RESOURCE(client, php_uv_t *, &z_cli, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-26 15:54:43 +02:00
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
r = uv_accept((uv_stream_t *)php_uv_get_current_stream(server), (uv_stream_t *)php_uv_get_current_stream(client));
|
2012-05-28 18:12:09 +02:00
|
|
|
if (r) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "accept");
|
2012-05-27 09:53:30 +02:00
|
|
|
}
|
2012-05-26 15:54:43 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-26 15:54:43 +02:00
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_shutdown)
|
|
|
|
{
|
|
|
|
zval *client, *callback = NULL;
|
|
|
|
php_uv_t *uv;
|
|
|
|
uv_shutdown_t *shutdown;
|
2012-07-01 13:09:19 +02:00
|
|
|
int r = 0;
|
2012-06-30 18:55:48 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r|z",&client, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
if (callback != NULL) {
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->shutdown_cb = callback;
|
|
|
|
}
|
|
|
|
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
shutdown = emalloc(sizeof(uv_shutdown_t));
|
|
|
|
shutdown->data = uv;
|
|
|
|
|
2012-07-01 13:09:19 +02:00
|
|
|
r = uv_shutdown(shutdown, (uv_stream_t*)php_uv_get_current_stream(uv), (uv_shutdown_cb)php_uv_shutdown_cb);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "shutdown failed");
|
|
|
|
}
|
|
|
|
|
2012-06-30 18:55:48 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-26 15:54:43 +02:00
|
|
|
PHP_FUNCTION(uv_close)
|
|
|
|
{
|
2012-05-29 01:00:17 +02:00
|
|
|
zval *client, *callback = NULL;
|
2012-05-26 15:54:43 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-29 01:00:17 +02:00
|
|
|
"r|z",&client, &callback) == FAILURE) {
|
2012-05-26 15:54:43 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-29 01:00:17 +02:00
|
|
|
if (callback != NULL) {
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->close_cb = callback;
|
|
|
|
}
|
2012-06-14 15:24:19 +02:00
|
|
|
|
2012-06-01 18:37:29 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-31 19:23:34 +02:00
|
|
|
uv_close((uv_handle_t*)php_uv_get_current_stream(uv), (uv_close_cb)php_uv_close_cb);
|
2012-05-26 15:54:43 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-26 15:54:43 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-24 06:07:52 +02:00
|
|
|
PHP_FUNCTION(uv_read_start)
|
|
|
|
{
|
|
|
|
zval *client, *callback;
|
2012-05-24 16:29:54 +02:00
|
|
|
php_uv_t *uv;
|
2012-05-29 00:28:58 +02:00
|
|
|
int r;
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-29 17:42:33 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_read_start\n");
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-05-24 06:07:52 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-25 01:07:12 +02:00
|
|
|
"rz",&client, &callback) == FAILURE) {
|
2012-05-24 06:07:52 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-05-26 09:49:50 +02:00
|
|
|
|
2012-05-24 16:29:54 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-26 07:05:17 +02:00
|
|
|
Z_ADDREF_P(callback);
|
2012-05-27 09:53:30 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-26 09:49:50 +02:00
|
|
|
|
2012-05-26 07:05:17 +02:00
|
|
|
uv->read_cb = callback;
|
2012-05-31 19:23:34 +02:00
|
|
|
if(uv->type == IS_UV_TCP) {
|
|
|
|
uv->uv.tcp.data = uv;
|
|
|
|
} else if(uv->type == IS_UV_PIPE) {
|
|
|
|
uv->uv.pipe.data = uv;
|
|
|
|
} else {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "this type does not support yet");
|
|
|
|
}
|
2012-05-26 09:49:50 +02:00
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
r = uv_read_start((uv_stream_t*)php_uv_get_current_stream(uv), php_uv_read_alloc, php_uv_read_cb);
|
2012-05-29 00:28:58 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "read failed");
|
|
|
|
}
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_read_start, uv->resource_id);
|
2012-05-23 19:31:16 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-23 19:31:16 +02:00
|
|
|
|
2012-07-01 01:25:16 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_read2_start)
|
|
|
|
{
|
|
|
|
zval *client, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
PHP_UV_DEBUG_PRINT("uv_read2_start\n");
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rz",&client, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
uv->read2_cb = callback;
|
|
|
|
if(uv->type == IS_UV_TCP) {
|
|
|
|
uv->uv.tcp.data = uv;
|
|
|
|
} else if(uv->type == IS_UV_PIPE) {
|
|
|
|
uv->uv.pipe.data = uv;
|
|
|
|
} else {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "this type does not support yet");
|
|
|
|
}
|
|
|
|
|
|
|
|
r = uv_read2_start((uv_stream_t*)php_uv_get_current_stream(uv), php_uv_read_alloc, php_uv_read2_cb);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "read2 failed");
|
|
|
|
}
|
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_read2_start, uv->resource_id);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-30 23:43:12 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_read_stop)
|
|
|
|
{
|
|
|
|
zval *server;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &server) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &server, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-02 08:06:39 +02:00
|
|
|
uv_read_stop((uv_stream_t*)php_uv_get_current_stream(uv));
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_read_stop, uv->resource_id);
|
2012-05-30 23:43:12 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_ip4_addr)
|
|
|
|
{
|
|
|
|
char *address;
|
|
|
|
int address_len = 0;
|
|
|
|
long port = 0;
|
|
|
|
php_uv_sockaddr_t *sockaddr;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"sl",&address, &address_len, &port) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
sockaddr = (php_uv_sockaddr_t*)emalloc(sizeof(php_uv_sockaddr_t));
|
|
|
|
|
|
|
|
sockaddr->is_ipv4 = 1;
|
|
|
|
sockaddr->addr.ipv4 = uv_ip4_addr(address, port);
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, sockaddr, uv_sockaddr_handle);
|
|
|
|
sockaddr->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-06-24 08:18:33 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_ip6_addr)
|
|
|
|
{
|
|
|
|
char *address;
|
|
|
|
int address_len = 0;
|
|
|
|
long port = 0;
|
|
|
|
php_uv_sockaddr_t *sockaddr;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"sl",&address, &address_len, &port) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
sockaddr = (php_uv_sockaddr_t*)emalloc(sizeof(php_uv_sockaddr_t));
|
|
|
|
|
|
|
|
sockaddr->is_ipv4 = 0;
|
|
|
|
sockaddr->addr.ipv6 = uv_ip6_addr(address, port);
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, sockaddr, uv_sockaddr_handle);
|
|
|
|
sockaddr->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-23 13:41:04 +02:00
|
|
|
PHP_FUNCTION(uv_listen)
|
|
|
|
{
|
2012-05-24 06:07:52 +02:00
|
|
|
zval *resource, *callback;
|
2012-05-23 13:41:04 +02:00
|
|
|
long backlog = SOMAXCONN;
|
|
|
|
php_uv_t *uv;
|
2012-05-27 06:48:10 +02:00
|
|
|
int r;
|
2012-05-23 13:41:04 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-24 06:07:52 +02:00
|
|
|
"zlz",&resource, &backlog, &callback) == FAILURE) {
|
2012-05-23 13:41:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-26 07:05:17 +02:00
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->listen_cb = callback;
|
2012-05-27 08:12:13 +02:00
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
r = uv_listen((uv_stream_t*)php_uv_get_current_stream(uv), backlog, php_uv_listen_cb);
|
2012-05-27 06:48:10 +02:00
|
|
|
if (r) {
|
2012-07-01 13:09:19 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "%s", uv_strerror(uv_last_error(uv_default_loop())));
|
2012-05-27 06:48:10 +02:00
|
|
|
}
|
2012-05-23 06:35:28 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
|
|
|
|
2012-05-23 06:35:28 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-23 06:35:28 +02:00
|
|
|
PHP_FUNCTION(uv_tcp_connect)
|
|
|
|
{
|
2012-05-28 18:12:09 +02:00
|
|
|
zval *resource,*address, *callback;
|
2012-05-23 06:35:28 +02:00
|
|
|
php_uv_t *uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
uv_connect_t *req;
|
2012-05-23 06:35:28 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-28 18:12:09 +02:00
|
|
|
"zzz",&resource,&address, &callback) == FAILURE) {
|
2012-05-23 06:35:28 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-28 18:12:09 +02:00
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
2012-06-01 05:54:52 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-28 15:55:58 +02:00
|
|
|
Z_ADDREF_P(callback);
|
2012-05-28 18:12:09 +02:00
|
|
|
Z_ADDREF_P(address);
|
2012-05-28 15:55:58 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
req = (uv_connect_t*)emalloc(sizeof(uv_connect_t));
|
2012-05-23 13:41:04 +02:00
|
|
|
|
2012-05-28 18:12:09 +02:00
|
|
|
req->data = uv;
|
|
|
|
uv->address = address;
|
|
|
|
uv->connect_cb = callback;
|
|
|
|
uv_tcp_connect(req, &uv->uv.tcp, addr->addr.ipv4, php_uv_tcp_connect_cb);
|
2012-05-23 06:35:28 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-23 06:35:28 +02:00
|
|
|
|
2012-06-24 09:28:04 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tcp_connect6)
|
|
|
|
{
|
|
|
|
zval *resource,*address, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
uv_connect_t *req;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zzz",&resource,&address, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
Z_ADDREF_P(address);
|
|
|
|
|
|
|
|
req = (uv_connect_t*)emalloc(sizeof(uv_connect_t));
|
|
|
|
|
|
|
|
req->data = uv;
|
|
|
|
uv->address = address;
|
|
|
|
uv->connect_cb = callback;
|
|
|
|
uv_tcp_connect6(req, &uv->uv.tcp, addr->addr.ipv6, php_uv_tcp_connect_cb);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-26 16:26:29 +02:00
|
|
|
PHP_FUNCTION(uv_timer_init)
|
|
|
|
{
|
|
|
|
int r;
|
2012-06-11 05:32:12 +02:00
|
|
|
zval *zloop = NULL;
|
2012-06-02 08:09:19 +02:00
|
|
|
uv_loop_t *loop;
|
2012-05-26 16:26:29 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-02 08:09:19 +02:00
|
|
|
"|z",&zloop) == FAILURE) {
|
2012-05-26 16:26:29 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-11 05:32:12 +02:00
|
|
|
if (zloop != NULL) {
|
2012-06-02 08:09:19 +02:00
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
2012-05-26 16:26:29 +02:00
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
|
2012-06-02 08:09:19 +02:00
|
|
|
r = uv_timer_init(loop, &uv->uv.timer);
|
2012-05-26 16:26:29 +02:00
|
|
|
if (r) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_timer_init failed");
|
2012-05-26 16:26:29 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-26 02:02:52 +02:00
|
|
|
uv->type = IS_UV_TIMER;
|
2012-05-26 16:26:29 +02:00
|
|
|
uv->uv.timer.data = uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
2012-06-25 18:27:06 +02:00
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-26 16:26:29 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-26 16:26:29 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-26 16:26:29 +02:00
|
|
|
PHP_FUNCTION(uv_timer_start)
|
|
|
|
{
|
|
|
|
//int uv_timer_start(uv_timer_t* handle, uv_timer_cb timer_cb, int64_t timeout,int64_t repeat) {
|
|
|
|
zval *timer, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long timeout, repeat = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rllz",&timer, &timeout, &repeat, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &timer, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
2012-06-01 05:54:52 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-26 16:26:29 +02:00
|
|
|
|
|
|
|
uv->timer_cb = callback;
|
|
|
|
uv_timer_start((uv_timer_t*)&uv->uv.timer, php_uv_timer_cb, timeout, repeat);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-26 16:26:29 +02:00
|
|
|
|
2012-05-31 00:11:52 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_timer_stop)
|
|
|
|
{
|
|
|
|
zval *timer;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&timer) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &timer, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
uv_timer_stop((uv_timer_t*)&uv->uv.timer);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_timer_again)
|
|
|
|
{
|
|
|
|
zval *timer;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&timer) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &timer, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
uv_timer_again((uv_timer_t*)&uv->uv.timer);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_timer_set_repeat)
|
|
|
|
{
|
|
|
|
zval *timer;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long repeat;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rl",&timer,&repeat) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &timer, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
uv_timer_set_repeat((uv_timer_t*)&uv->uv.timer,repeat);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_timer_get_repeat)
|
|
|
|
{
|
|
|
|
zval *timer;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int64_t repeat;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&timer) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &timer, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
repeat = uv_timer_get_repeat((uv_timer_t*)&uv->uv.timer);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 05:29:15 +02:00
|
|
|
PHP_FUNCTION(uv_idle_start)
|
|
|
|
{
|
2012-05-28 05:37:56 +02:00
|
|
|
zval *idle, *callback;
|
2012-05-28 05:29:15 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-28 05:37:56 +02:00
|
|
|
"rz",&idle, &callback) == FAILURE) {
|
2012-05-28 05:29:15 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-05-28 05:37:56 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &idle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-28 05:29:15 +02:00
|
|
|
Z_ADDREF_P(callback);
|
2012-06-30 06:02:53 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-29 13:10:46 +02:00
|
|
|
|
|
|
|
if (uv->idle_cb) {
|
|
|
|
zval_ptr_dtor(&uv->idle_cb);
|
|
|
|
uv->idle_cb = NULL;
|
|
|
|
}
|
2012-05-28 05:29:15 +02:00
|
|
|
|
|
|
|
uv->idle_cb = callback;
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_idle_start((uv_idle_t*)&uv->uv.idle, (uv_idle_cb)php_uv_idle_cb);
|
2012-05-28 05:29:15 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 05:29:15 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_FUNCTION(uv_getaddrinfo)
|
|
|
|
{
|
2012-06-23 20:34:06 +02:00
|
|
|
zval *z_loop, *hints, *callback = NULL;
|
2012-05-28 18:12:09 +02:00
|
|
|
uv_loop_t *loop;
|
2012-06-18 15:32:15 +02:00
|
|
|
php_uv_t *uv = NULL;
|
2012-06-23 20:34:06 +02:00
|
|
|
struct addrinfo hint = {0};
|
|
|
|
char *node, *service;
|
|
|
|
int node_len, service_len = 0;
|
2012-05-28 18:12:09 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-23 20:34:06 +02:00
|
|
|
"zzss|a",&z_loop, &callback, &node, &node_len, &service, &service_len, &hints) == FAILURE) {
|
2012-05-28 18:12:09 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
2012-06-23 20:34:06 +02:00
|
|
|
|
|
|
|
if (Z_TYPE_P(hints) == IS_ARRAY) {
|
|
|
|
HashTable *h;
|
|
|
|
zval **data;
|
|
|
|
|
|
|
|
h = Z_ARRVAL_P(hints);
|
|
|
|
if (zend_hash_find(h, "ai_family", sizeof("ai_family"), (void **)&data) == SUCCESS) {
|
|
|
|
hint.ai_family = Z_LVAL_PP(data);
|
|
|
|
}
|
|
|
|
if (zend_hash_find(h, "ai_socktype", sizeof("ai_socktype"), (void **)&data) == SUCCESS) {
|
|
|
|
hint.ai_socktype = Z_LVAL_PP(data);
|
|
|
|
}
|
|
|
|
if (zend_hash_find(h, "ai_protocol", sizeof("ai_socktype"), (void **)&data) == SUCCESS) {
|
|
|
|
hint.ai_socktype = Z_LVAL_PP(data);
|
|
|
|
}
|
|
|
|
if (zend_hash_find(h, "ai_flags", sizeof("ai_flags"), (void **)&data) == SUCCESS) {
|
|
|
|
hint.ai_flags = Z_LVAL_PP(data);
|
|
|
|
}
|
|
|
|
}
|
2012-05-28 18:12:09 +02:00
|
|
|
|
2012-06-23 20:34:06 +02:00
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-28 18:12:09 +02:00
|
|
|
uv->getaddr_cb = callback;
|
2012-06-23 20:34:06 +02:00
|
|
|
uv->uv.addrinfo.data = uv;
|
2012-06-25 17:30:45 +02:00
|
|
|
uv->resource_id = PHP_UV_LIST_INSERT(uv, uv_resource_handle);
|
2012-06-23 20:34:06 +02:00
|
|
|
|
|
|
|
uv_getaddrinfo(loop, &uv->uv.addrinfo, php_uv_getaddrinfo_cb, node, service, &hint);
|
2012-05-28 18:12:09 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 05:29:15 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 05:37:56 +02:00
|
|
|
PHP_FUNCTION(uv_idle_stop)
|
|
|
|
{
|
|
|
|
zval *idle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &idle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &idle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_idle_stop((uv_idle_t*)&uv->uv.idle);
|
2012-05-28 05:37:56 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 05:37:56 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-23 06:35:28 +02:00
|
|
|
PHP_FUNCTION(uv_tcp_init)
|
|
|
|
{
|
2012-05-23 13:41:04 +02:00
|
|
|
int r;
|
2012-06-11 05:30:13 +02:00
|
|
|
zval *zloop = NULL;
|
2012-06-02 08:09:19 +02:00
|
|
|
uv_loop_t *loop;
|
2012-05-23 06:35:28 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-11 05:30:13 +02:00
|
|
|
"|z",&zloop) == FAILURE) {
|
2012-05-23 13:41:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-05-24 16:29:54 +02:00
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
2012-05-27 07:43:27 +02:00
|
|
|
if (!uv) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_tcp_init emalloc failed");
|
2012-05-27 07:43:27 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-11 05:30:13 +02:00
|
|
|
if (zloop != NULL) {
|
2012-06-02 08:09:19 +02:00
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
2012-05-24 16:29:54 +02:00
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
uv->type = IS_UV_TCP;
|
2012-06-02 08:09:19 +02:00
|
|
|
r = uv_tcp_init(loop, &uv->uv.tcp);
|
2012-05-23 13:41:04 +02:00
|
|
|
if (r) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_tcp_init failed");
|
2012-05-23 06:35:28 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-05-27 07:43:27 +02:00
|
|
|
|
2012-05-26 15:59:59 +02:00
|
|
|
uv->uv.tcp.data = uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-23 06:35:28 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
2012-05-26 15:25:15 +02:00
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
2012-05-23 06:35:28 +02:00
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
2012-05-28 05:29:15 +02:00
|
|
|
PHP_FUNCTION(uv_idle_init)
|
|
|
|
{
|
|
|
|
int r;
|
2012-06-19 01:05:50 +02:00
|
|
|
zval *zloop = NULL;
|
2012-06-02 08:09:19 +02:00
|
|
|
uv_loop_t *loop;
|
2012-05-28 05:29:15 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-19 01:05:50 +02:00
|
|
|
"|z",&zloop) == FAILURE) {
|
2012-05-28 05:29:15 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-19 01:05:50 +02:00
|
|
|
if (zloop != NULL) {
|
2012-06-02 08:09:19 +02:00
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
2012-05-28 05:29:15 +02:00
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
|
2012-06-02 08:09:19 +02:00
|
|
|
r = uv_idle_init(loop, &uv->uv.idle);
|
2012-05-28 05:29:15 +02:00
|
|
|
if (r) {
|
2012-05-29 00:28:58 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_idle_init failed");
|
2012-05-28 05:29:15 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
uv->uv.timer.data = uv;
|
2012-05-28 18:12:09 +02:00
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-28 05:29:15 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 05:29:15 +02:00
|
|
|
|
2012-05-29 00:35:55 +02:00
|
|
|
/* {{{ */
|
2012-05-28 15:18:36 +02:00
|
|
|
PHP_FUNCTION(uv_default_loop)
|
|
|
|
{
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, php_uv_default_loop(), uv_loop_handle);
|
|
|
|
}
|
2012-05-29 00:35:55 +02:00
|
|
|
/* }}} */
|
2012-05-28 15:18:36 +02:00
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_init)
|
|
|
|
{
|
|
|
|
int r;
|
2012-06-02 08:09:19 +02:00
|
|
|
zval *zloop;
|
2012-06-18 15:32:15 +02:00
|
|
|
uv_loop_t *loop = NULL;
|
2012-05-29 18:47:30 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-02 08:09:19 +02:00
|
|
|
"|z",&zloop) == FAILURE) {
|
2012-05-29 18:47:30 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-02 08:09:19 +02:00
|
|
|
if (loop) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_udp_init emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_UDP;
|
2012-06-02 08:09:19 +02:00
|
|
|
r = uv_udp_init(loop, &uv->uv.udp);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_udp_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->uv.udp.data = uv;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_bind)
|
|
|
|
{
|
2012-06-02 14:45:43 +02:00
|
|
|
zval *resource, *address;
|
2012-05-29 18:47:30 +02:00
|
|
|
long flags = 0;
|
2012-06-02 14:45:43 +02:00
|
|
|
php_uv_sockaddr_t *addr;
|
2012-05-29 18:47:30 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-02 14:45:43 +02:00
|
|
|
"zz|l",&resource, &address, &flags) == FAILURE) {
|
2012-05-29 18:47:30 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-02 14:45:43 +02:00
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
2012-05-29 18:47:30 +02:00
|
|
|
|
2012-06-02 14:45:43 +02:00
|
|
|
r = uv_udp_bind((uv_udp_t*)&uv->uv.udp, addr->addr.ipv4, flags);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_udp_bind failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 09:28:04 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_bind6)
|
|
|
|
{
|
|
|
|
zval *resource, *address;
|
|
|
|
long flags = 0;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zz|l",&resource, &address, &flags) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
|
|
|
|
r = uv_udp_bind6((uv_udp_t*)&uv->uv.udp, addr->addr.ipv6, flags);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_udp_bind6 failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_recv_start)
|
|
|
|
{
|
|
|
|
zval *client, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rz",&client, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
uv->udp_recv_cb = callback;
|
|
|
|
uv->uv.udp.data = uv;
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
r = uv_udp_recv_start((uv_udp_t*)&uv->uv.udp, php_uv_read_alloc, php_uv_udp_recv_cb);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "read failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_recv_stop)
|
|
|
|
{
|
|
|
|
zval *client;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &client) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
uv_udp_recv_stop((uv_udp_t*)&uv->uv.udp);
|
2012-05-29 18:47:30 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 15:33:47 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_set_membership)
|
|
|
|
{
|
|
|
|
zval *client;
|
|
|
|
php_uv_t *uv;
|
2012-06-25 18:04:16 +02:00
|
|
|
char *multicast_addr, interface_addr;
|
2012-06-24 15:33:47 +02:00
|
|
|
int error, multicast_addr_len, interface_addr_len = 0;
|
|
|
|
long membership;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rssl", &client, &multicast_addr, &multicast_addr_len, &interface_addr, &interface_addr_len, &membership) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
error = uv_udp_set_membership((uv_udp_t*)&uv->uv.udp, (const char*)multicast_addr, (const char*)interface_addr, (int)membership);
|
2012-06-24 15:33:47 +02:00
|
|
|
|
|
|
|
RETURN_LONG(error);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-05-29 18:47:30 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_set_multicast_loop)
|
|
|
|
{
|
|
|
|
zval *client;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long enabled = 0;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rl",&client, &enabled) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
r = uv_udp_set_multicast_loop((uv_udp_t*)&uv->uv.udp, enabled);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_udp_set_muticast_loop failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_set_multicast_ttl)
|
|
|
|
{
|
|
|
|
zval *client;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long ttl = 0; /* 1 through 255 */
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rl",&client, &ttl) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
r = uv_udp_set_multicast_ttl((uv_udp_t*)&uv->uv.udp, ttl);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_udp_set_muticast_ttl failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_set_broadcast)
|
|
|
|
{
|
|
|
|
zval *client;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long enabled = 0;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rl",&client, &enabled) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &client, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-05-30 15:32:11 +02:00
|
|
|
r = uv_udp_set_broadcast((uv_udp_t*)&uv->uv.udp, enabled);
|
2012-05-29 18:47:30 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "uv_udp_set_muticast_loop failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_send)
|
|
|
|
{
|
|
|
|
zval *z_cli,*z_addr, *callback;
|
|
|
|
char *data;
|
|
|
|
int data_len = 0;
|
|
|
|
php_uv_t *client;
|
|
|
|
send_req_t *w;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zszz",&z_cli, &data, &data_len, &z_addr, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(client, php_uv_t *, &z_cli, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &z_addr, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
client->udp_send_cb = callback;
|
2012-06-01 05:54:52 +02:00
|
|
|
zend_list_addref(client->resource_id);
|
2012-05-29 18:47:30 +02:00
|
|
|
|
|
|
|
w = emalloc(sizeof(send_req_t));
|
|
|
|
w->req.data = client;
|
|
|
|
w->buf = uv_buf_init(estrndup(data,data_len), data_len);
|
|
|
|
uv_udp_send(&w->req, &client->uv.udp, &w->buf, 1, addr->addr.ipv4, php_uv_udp_send_cb);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-30 23:59:21 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_is_active)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
r = uv_is_active((uv_handle_t*)php_uv_get_current_stream(uv));
|
|
|
|
RETURN_BOOL(r);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_is_readable)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
r = uv_is_readable((uv_stream_t*)php_uv_get_current_stream(uv));
|
|
|
|
RETURN_BOOL(r);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-05-31 06:39:30 +02:00
|
|
|
|
2012-05-30 23:59:21 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_is_writable)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r",&handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
r = uv_is_writable((uv_stream_t*)php_uv_get_current_stream(uv));
|
|
|
|
RETURN_BOOL(r);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-05-29 18:47:30 +02:00
|
|
|
|
2012-05-31 06:39:30 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_pipe_init)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
2012-06-24 18:29:22 +02:00
|
|
|
uv_loop_t *loop;
|
2012-05-31 19:23:34 +02:00
|
|
|
zval *z_loop;
|
2012-05-31 06:39:30 +02:00
|
|
|
long ipc = 0;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|z|l", &z_loop, &ipc) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_pipe_init emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
2012-06-24 18:29:22 +02:00
|
|
|
|
|
|
|
if (Z_TYPE_P(z_loop) == IS_RESOURCE) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &z_loop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = php_uv_default_loop();
|
|
|
|
}
|
2012-05-31 06:39:30 +02:00
|
|
|
|
|
|
|
uv->type = IS_UV_PIPE;
|
2012-06-24 18:29:22 +02:00
|
|
|
r = uv_pipe_init(loop, &uv->uv.pipe, ipc);
|
2012-05-31 06:39:30 +02:00
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_pipe_init failed");
|
|
|
|
return;
|
|
|
|
}
|
2012-06-24 18:29:22 +02:00
|
|
|
|
2012-05-31 06:39:30 +02:00
|
|
|
uv->uv.pipe.data = uv;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
2012-05-31 06:39:30 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_pipe_open)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
2012-05-31 19:23:34 +02:00
|
|
|
zval *handle;
|
|
|
|
/* TODO: `pipe` correct? */
|
|
|
|
long pipe = 0;
|
2012-05-31 06:39:30 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-05-31 19:23:34 +02:00
|
|
|
"zl",&handle, &pipe) == FAILURE) {
|
2012-05-31 06:39:30 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
uv_pipe_open(&uv->uv.pipe, pipe);
|
2012-05-31 06:39:30 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_pipe_bind)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle;
|
|
|
|
char *name;
|
|
|
|
int name_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zs",&handle, &name, &name_len) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
uv_pipe_bind(&uv->uv.pipe, name);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-05-31 19:23:34 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_pipe_connect)
|
|
|
|
{
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *resource, *callback;
|
|
|
|
zval *address = NULL;
|
2012-05-31 19:23:34 +02:00
|
|
|
php_uv_t *uv;
|
|
|
|
char *name;
|
|
|
|
int name_len = 0;
|
|
|
|
uv_connect_t *req;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz",&resource,&name, &name_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &resource, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
2012-06-01 18:37:29 +02:00
|
|
|
zend_list_addref(uv->resource_id);
|
2012-05-31 19:23:34 +02:00
|
|
|
|
|
|
|
req = (uv_connect_t*)emalloc(sizeof(uv_connect_t));
|
|
|
|
|
|
|
|
req->data = uv;
|
|
|
|
uv->address = address;
|
|
|
|
uv->pipe_connect_cb = callback;
|
|
|
|
uv_pipe_connect(req, (uv_pipe_t*)php_uv_get_current_stream(uv), name, php_uv_pipe_connect_cb);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-02 08:29:31 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_pipe_pending_instances)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle;
|
|
|
|
long count;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zl",&handle, &count) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
uv_pipe_pending_instances(&uv->uv.pipe, count);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-03 17:10:30 +02:00
|
|
|
static void php_ares_gethostbyname_cb( void *arg, int status, int timeouts, struct hostent *hostent)
|
|
|
|
{
|
|
|
|
TSRMLS_FETCH();
|
|
|
|
zval *retval_ptr, *hostname, *addresses = NULL;
|
|
|
|
zval **params[2];
|
2012-06-03 18:23:03 +02:00
|
|
|
php_uv_ares_t *uv = (php_uv_ares_t*)arg;
|
2012-06-03 17:10:30 +02:00
|
|
|
struct in_addr **ptr;
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(hostname);
|
|
|
|
ZVAL_STRING(hostname, hostent->h_name, 1);
|
|
|
|
MAKE_STD_ZVAL(addresses);
|
|
|
|
|
|
|
|
array_init(addresses);
|
|
|
|
ptr = (struct in_addr **)hostent->h_addr_list;
|
|
|
|
while(*ptr != NULL) {
|
|
|
|
add_next_index_string(addresses, inet_ntoa(**(ptr++)), 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
params[0] = &hostname;
|
|
|
|
params[1] = &addresses;
|
|
|
|
|
|
|
|
php_uv_do_callback(&retval_ptr, uv->gethostbyname_cb, params, 2 TSRMLS_CC);
|
|
|
|
|
|
|
|
zval_ptr_dtor(&retval_ptr);
|
|
|
|
zval_ptr_dtor(&hostname);
|
|
|
|
zval_ptr_dtor(&addresses);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_ares_init_options)
|
|
|
|
{
|
|
|
|
int rc, length;
|
|
|
|
int optmask = ARES_OPT_SERVERS | ARES_OPT_TCP_PORT | ARES_OPT_LOOKUPS | ARES_OPT_FLAGS;
|
|
|
|
zval **data, *zoptions, *zloop = NULL;
|
|
|
|
uv_loop_t *loop = NULL;
|
2012-06-03 18:23:03 +02:00
|
|
|
php_uv_ares_t *uv;
|
2012-06-03 17:10:30 +02:00
|
|
|
HashTable *h;
|
|
|
|
struct in_addr *addresses;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zal",&zloop,&zoptions, &optmask) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Z_TYPE_P(zloop) == IS_RESOURCE) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t *, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = php_uv_default_loop();
|
|
|
|
}
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
uv = (php_uv_ares_t*)emalloc(sizeof(php_uv_ares_t));
|
2012-06-30 19:13:12 +02:00
|
|
|
uv->gethostbyname_cb = NULL;
|
|
|
|
|
2012-06-03 17:10:30 +02:00
|
|
|
h = Z_ARRVAL_P(zoptions);
|
|
|
|
if (zend_hash_find(h, "servers", sizeof("servers"), (void **)&data) == SUCCESS) {
|
|
|
|
HashTable *servers = Z_ARRVAL_P(*data);
|
|
|
|
HashPosition pos;
|
|
|
|
char *key;
|
|
|
|
int key_type;
|
|
|
|
uint key_len;
|
|
|
|
ulong key_index;
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
length = zend_hash_num_elements(servers);
|
|
|
|
addresses = (struct in_addr*)ecalloc(length, sizeof(struct in_addr));
|
|
|
|
for (zend_hash_internal_pointer_reset_ex(servers, &pos);
|
|
|
|
(key_type = zend_hash_get_current_key_ex(servers, &key, &key_len, &key_index, 0, &pos)) != HASH_KEY_NON_EXISTANT;
|
|
|
|
zend_hash_move_forward_ex(servers, &pos)) {
|
|
|
|
struct sockaddr_in address;
|
|
|
|
zval **value;
|
|
|
|
|
|
|
|
zend_hash_get_current_data_ex(servers, (void *) &value, &pos);
|
|
|
|
if (Z_TYPE_PP(value) != IS_STRING) {
|
2012-06-03 18:23:03 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "servers value must be an array");
|
2012-06-03 17:10:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
address = uv_ip4_addr(Z_STRVAL_PP(value),0);
|
|
|
|
addresses[i] = address.sin_addr;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
if (zend_hash_find(h, "port", sizeof("port"), (void **)&data) == SUCCESS) {
|
2012-06-03 18:23:03 +02:00
|
|
|
uv->options.tcp_port = htonl(Z_LVAL_PP(data));
|
2012-06-03 17:10:30 +02:00
|
|
|
}
|
|
|
|
if (zend_hash_find(h, "lookups", sizeof("lookups"), (void **)&data) == SUCCESS) {
|
2012-06-03 18:23:03 +02:00
|
|
|
uv->options.lookups = Z_STRVAL_PP(data);
|
2012-06-03 17:10:30 +02:00
|
|
|
}
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
uv->options.servers = addresses;
|
|
|
|
uv->options.nservers = length;
|
|
|
|
uv->options.flags = ARES_FLAG_USEVC;
|
2012-06-03 17:10:30 +02:00
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
rc = uv_ares_init_options(loop, &uv->channel, &uv->options, optmask);
|
2012-06-03 17:10:30 +02:00
|
|
|
if (rc) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_ares_init_options failed");
|
|
|
|
}
|
|
|
|
efree(addresses);
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_ares_handle);
|
2012-06-03 17:10:30 +02:00
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(ares_gethostbyname)
|
|
|
|
{
|
|
|
|
zval *handle, *byname_cb;
|
|
|
|
long flag = AF_INET;
|
|
|
|
char *name;
|
|
|
|
int name_len;
|
2012-06-03 18:23:03 +02:00
|
|
|
php_uv_ares_t *uv;
|
2012-06-03 17:10:30 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zslz",&handle, &name, &name_len, &flag, &byname_cb) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_ares_t *, &handle, -1, PHP_UV_ARES_RESOURCE_NAME, uv_ares_handle);
|
2012-06-30 05:35:01 +02:00
|
|
|
if (uv->gethostbyname_cb != NULL) {
|
|
|
|
zval_ptr_dtor(&uv->gethostbyname_cb);
|
|
|
|
uv->gethostbyname_cb = NULL;
|
|
|
|
}
|
2012-06-03 17:10:30 +02:00
|
|
|
Z_ADDREF_P(byname_cb);
|
|
|
|
uv->gethostbyname_cb = byname_cb;
|
|
|
|
|
2012-06-03 18:23:03 +02:00
|
|
|
ares_gethostbyname(uv->channel,
|
2012-06-03 17:10:30 +02:00
|
|
|
name,
|
|
|
|
flag,
|
|
|
|
&php_ares_gethostbyname_cb,
|
|
|
|
uv
|
|
|
|
);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto array uv_loadavg(void)
|
|
|
|
*/
|
2012-06-04 18:12:13 +02:00
|
|
|
PHP_FUNCTION(uv_loadavg)
|
|
|
|
{
|
|
|
|
zval *retval;
|
|
|
|
double average[3];
|
|
|
|
|
|
|
|
uv_loadavg(average);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(retval);
|
|
|
|
array_init(retval);
|
|
|
|
add_next_index_double(retval, average[0]);
|
|
|
|
add_next_index_double(retval, average[1]);
|
|
|
|
add_next_index_double(retval, average[2]);
|
|
|
|
|
|
|
|
RETURN_ZVAL(retval,0,1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto double uv_uptime(void)
|
|
|
|
*/
|
2012-06-04 18:12:13 +02:00
|
|
|
PHP_FUNCTION(uv_uptime)
|
|
|
|
{
|
|
|
|
uv_err_t error;
|
|
|
|
double uptime;
|
|
|
|
|
|
|
|
error = uv_uptime(&uptime);
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
RETURN_DOUBLE(uptime);
|
2012-06-04 18:12:13 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto long uv_get_free_memory(void)
|
|
|
|
*/
|
2012-06-16 09:32:46 +02:00
|
|
|
PHP_FUNCTION(uv_get_free_memory)
|
|
|
|
{
|
|
|
|
RETURN_LONG(uv_get_free_memory());
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto long uv_get_total_memory(void)
|
|
|
|
*/
|
2012-06-16 09:32:46 +02:00
|
|
|
PHP_FUNCTION(uv_get_total_memory)
|
|
|
|
{
|
|
|
|
RETURN_LONG(uv_get_total_memory());
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto long uv_hrtime(void)
|
|
|
|
*/
|
2012-06-16 09:32:46 +02:00
|
|
|
PHP_FUNCTION(uv_hrtime)
|
|
|
|
{
|
2012-06-24 17:18:32 +02:00
|
|
|
/* TODO: is this correct? */
|
2012-06-16 09:32:46 +02:00
|
|
|
RETURN_LONG(uv_hrtime());
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto string uv_exepath(void)
|
|
|
|
*/
|
2012-06-16 09:39:43 +02:00
|
|
|
PHP_FUNCTION(uv_exepath)
|
|
|
|
{
|
|
|
|
char buffer[1024] = {0};
|
2012-06-24 17:18:32 +02:00
|
|
|
size_t buffer_sz;
|
2012-06-16 09:39:43 +02:00
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
buffer_sz = sizeof(buffer);
|
2012-06-16 09:39:43 +02:00
|
|
|
uv_exepath(buffer, &buffer_sz);
|
|
|
|
buffer[buffer_sz] = '\0';
|
|
|
|
|
|
|
|
RETURN_STRINGL(buffer, buffer_sz, 1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-16 09:32:46 +02:00
|
|
|
|
2012-06-30 09:31:19 +02:00
|
|
|
/* {{{ proto string uv_cwd(void) */
|
2012-06-16 09:43:02 +02:00
|
|
|
PHP_FUNCTION(uv_cwd)
|
|
|
|
{
|
|
|
|
char buffer[1024] = {0};
|
|
|
|
size_t buffer_sz = sizeof(buffer);
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
uv_cwd(buffer, buffer_sz);
|
2012-06-16 09:43:02 +02:00
|
|
|
buffer[buffer_sz] = '\0';
|
|
|
|
|
2012-06-25 06:05:26 +02:00
|
|
|
RETURN_STRING(buffer, 1);
|
2012-06-16 09:43:02 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
/* {{{ proto array uv_cpu_info(void)
|
|
|
|
*/
|
2012-06-04 18:12:13 +02:00
|
|
|
PHP_FUNCTION(uv_cpu_info)
|
|
|
|
{
|
|
|
|
zval *retval;
|
|
|
|
uv_cpu_info_t *cpus;
|
|
|
|
uv_err_t error;
|
|
|
|
int i, count;
|
|
|
|
|
|
|
|
error = uv_cpu_info(&cpus, &count);
|
|
|
|
if (UV_OK == error.code) {
|
|
|
|
MAKE_STD_ZVAL(retval);
|
|
|
|
array_init(retval);
|
|
|
|
|
|
|
|
for (i = 0; i < count; i++) {
|
|
|
|
zval *tmp, *times;
|
2012-06-24 17:18:32 +02:00
|
|
|
|
2012-06-04 18:12:13 +02:00
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
MAKE_STD_ZVAL(times);
|
2012-06-24 17:18:32 +02:00
|
|
|
array_init(tmp);
|
2012-06-04 18:12:13 +02:00
|
|
|
array_init(times);
|
|
|
|
|
|
|
|
add_assoc_string_ex(tmp, "model", sizeof("model"), cpus[i].model, 1);
|
|
|
|
add_assoc_long_ex(tmp, "speed", sizeof("speed"), cpus[i].speed);
|
|
|
|
|
2012-06-24 17:18:32 +02:00
|
|
|
add_assoc_long_ex(times, "sys", sizeof("sys"), (size_t)cpus[i].cpu_times.sys);
|
|
|
|
add_assoc_long_ex(times, "user", sizeof("user"), (size_t)cpus[i].cpu_times.user);
|
|
|
|
add_assoc_long_ex(times, "idle", sizeof("idle"), (size_t)cpus[i].cpu_times.idle);
|
|
|
|
add_assoc_long_ex(times, "irq", sizeof("irq"), (size_t)cpus[i].cpu_times.irq);
|
|
|
|
add_assoc_long_ex(times, "nice", sizeof("nice"), (size_t)cpus[i].cpu_times.nice);
|
|
|
|
add_assoc_zval_ex(tmp, "times", sizeof("times"), times);
|
2012-06-04 18:12:13 +02:00
|
|
|
|
|
|
|
add_next_index_zval(retval,tmp);
|
|
|
|
}
|
2012-06-24 17:18:32 +02:00
|
|
|
|
2012-06-04 18:12:13 +02:00
|
|
|
uv_free_cpu_info(cpus, count);
|
|
|
|
RETURN_ZVAL(retval,0,1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_interface_addresses)
|
|
|
|
{
|
|
|
|
zval *retval;
|
|
|
|
uv_interface_address_t *interfaces;
|
|
|
|
uv_err_t error;
|
|
|
|
char buffer[512];
|
|
|
|
int i, count;
|
|
|
|
|
|
|
|
error = uv_interface_addresses(&interfaces, &count);
|
|
|
|
if (UV_OK == error.code) {
|
|
|
|
MAKE_STD_ZVAL(retval);
|
|
|
|
array_init(retval);
|
|
|
|
|
|
|
|
for (i = 0; i < count; i++) {
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *tmp;
|
2012-06-04 18:12:13 +02:00
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
array_init(tmp);
|
|
|
|
add_assoc_string_ex(tmp, "name", sizeof("name"), interfaces[i].name , 1);
|
|
|
|
add_assoc_bool_ex(tmp, "is_internal", sizeof("is_internal"), interfaces[i].is_internal);
|
|
|
|
|
|
|
|
if (interfaces[i].address.address4.sin_family == AF_INET) {
|
|
|
|
uv_ip4_name(&interfaces[i].address.address4, buffer, sizeof(buffer));
|
|
|
|
} else if (interfaces[i].address.address4.sin_family == AF_INET6) {
|
|
|
|
uv_ip6_name(&interfaces[i].address.address6, buffer, sizeof(buffer));
|
|
|
|
}
|
|
|
|
add_assoc_string_ex(tmp, "address", sizeof("address"), buffer, 1);
|
|
|
|
|
|
|
|
add_next_index_zval(retval,tmp);
|
|
|
|
}
|
|
|
|
uv_free_interface_addresses(interfaces, count);
|
|
|
|
RETURN_ZVAL(retval,0,1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-05-31 06:39:30 +02:00
|
|
|
|
2012-06-13 12:42:12 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_spawn)
|
|
|
|
{
|
|
|
|
zval *zloop = NULL;
|
|
|
|
uv_loop_t *loop;
|
2012-06-14 15:24:19 +02:00
|
|
|
uv_process_options_t options = {0};
|
2012-06-24 18:29:22 +02:00
|
|
|
uv_stdio_container_t stdio[3];
|
2012-06-14 15:24:19 +02:00
|
|
|
php_uv_t *proc;
|
|
|
|
zval *args, *context, *callback;
|
2012-06-15 15:47:46 +02:00
|
|
|
char **zenv;
|
2012-06-14 15:24:19 +02:00
|
|
|
char *command;
|
2012-06-14 16:07:12 +02:00
|
|
|
char **command_args;
|
2012-06-14 15:24:19 +02:00
|
|
|
int command_len = 0;
|
2012-06-13 12:42:12 +02:00
|
|
|
|
2012-06-24 18:29:22 +02:00
|
|
|
options.stdio = stdio;
|
|
|
|
options.stdio_count = 3;
|
|
|
|
|
2012-06-13 12:42:12 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-14 15:24:19 +02:00
|
|
|
"zsaaz", &zloop, &command, &command_len, &args, &context, &callback) == FAILURE) {
|
2012-06-13 12:42:12 +02:00
|
|
|
return;
|
|
|
|
}
|
2012-06-14 15:24:19 +02:00
|
|
|
|
2012-06-13 12:42:12 +02:00
|
|
|
if (zloop) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
2012-06-14 16:07:12 +02:00
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
{
|
|
|
|
HashTable *h;
|
|
|
|
zval **data;
|
2012-06-18 15:32:15 +02:00
|
|
|
h = Z_ARRVAL_P(context);
|
2012-06-14 16:07:12 +02:00
|
|
|
|
|
|
|
if (zend_hash_find(h, "cwd", sizeof("cwd"), (void **)&data) == SUCCESS) {
|
|
|
|
options.cwd = Z_STRVAL_PP(data);
|
|
|
|
}
|
2012-06-14 15:24:19 +02:00
|
|
|
|
2012-06-15 15:47:46 +02:00
|
|
|
if (zend_hash_find(h, "env", sizeof("env"), (void **)&data) == SUCCESS) {
|
|
|
|
HashTable *env;
|
|
|
|
HashPosition pos;
|
|
|
|
char *key;
|
|
|
|
int key_type;
|
|
|
|
uint key_len;
|
|
|
|
ulong key_index;
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
env = Z_ARRVAL_P(*data);
|
|
|
|
|
|
|
|
zenv = emalloc(sizeof(char*) * (zend_hash_num_elements(env)+1));
|
|
|
|
for (zend_hash_internal_pointer_reset_ex(env, &pos);
|
|
|
|
(key_type = zend_hash_get_current_key_ex(env, &key, &key_len, &key_index, 0, &pos)) != HASH_KEY_NON_EXISTANT;
|
|
|
|
zend_hash_move_forward_ex(env, &pos)) {
|
|
|
|
|
|
|
|
zval **value;
|
|
|
|
char *hoge;
|
|
|
|
zend_hash_get_current_data_ex(env, (void *) &value, &pos);
|
|
|
|
|
|
|
|
hoge = emalloc(sizeof(char)*key_len+1+Z_STRLEN_PP(value));
|
|
|
|
slprintf(hoge,key_len+1+Z_STRLEN_PP(value),"%s=%s",key, Z_STRVAL_PP(value));
|
2012-06-15 16:29:36 +02:00
|
|
|
zenv[i] = hoge;
|
2012-06-15 15:47:46 +02:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
zenv[i] = NULL;
|
|
|
|
options.env = zenv;
|
|
|
|
}
|
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
if (zend_hash_find(h, "pipes", sizeof("pipes"), (void **)&data) == SUCCESS) {
|
|
|
|
HashTable *pipes;
|
|
|
|
HashPosition pos;
|
|
|
|
char *key;
|
|
|
|
int key_type;
|
|
|
|
uint key_len;
|
|
|
|
ulong key_index;
|
|
|
|
|
|
|
|
pipes = Z_ARRVAL_P(*data);
|
|
|
|
|
|
|
|
for (zend_hash_internal_pointer_reset_ex(pipes, &pos);
|
|
|
|
(key_type = zend_hash_get_current_key_ex(pipes, &key, &key_len, &key_index, 0, &pos)) != HASH_KEY_NON_EXISTANT;
|
|
|
|
zend_hash_move_forward_ex(pipes, &pos)) {
|
|
|
|
|
|
|
|
zval **value;
|
|
|
|
php_uv_t *pipe;
|
|
|
|
|
|
|
|
zend_hash_get_current_data_ex(pipes, (void *) &value, &pos);
|
|
|
|
if (Z_TYPE_PP(value) != IS_RESOURCE) {
|
2012-06-14 16:07:12 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "must be uv_pipe resource");
|
2012-06-14 15:24:19 +02:00
|
|
|
}
|
2012-06-14 16:07:12 +02:00
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
ZEND_FETCH_RESOURCE(pipe, php_uv_t *, value, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
|
|
|
|
if (pos->h == 0) {
|
2012-06-24 18:29:22 +02:00
|
|
|
options.stdio[0].flags = UV_CREATE_PIPE | UV_READABLE_PIPE;
|
|
|
|
options.stdio[0].data.stream = (uv_stream_t *)&pipe->uv.pipe;
|
2012-06-14 16:07:12 +02:00
|
|
|
} else if (pos->h == 1) {
|
2012-06-24 18:29:22 +02:00
|
|
|
options.stdio[1].flags = UV_CREATE_PIPE | UV_WRITABLE_PIPE;
|
|
|
|
options.stdio[1].data.stream = (uv_stream_t *)&pipe->uv.pipe;
|
2012-06-14 16:07:12 +02:00
|
|
|
} else if (pos->h == 2) {
|
2012-06-24 18:29:22 +02:00
|
|
|
options.stdio[2].flags = UV_CREATE_PIPE | UV_WRITABLE_PIPE;
|
|
|
|
options.stdio[2].data.stream = (uv_stream_t *)&pipe->uv.pipe;
|
2012-06-14 15:24:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-14 16:07:12 +02:00
|
|
|
{
|
|
|
|
HashTable *h;
|
|
|
|
HashPosition pos;
|
|
|
|
char *key;
|
|
|
|
int key_type;
|
|
|
|
uint key_len;
|
|
|
|
ulong key_index;
|
2012-06-18 15:32:15 +02:00
|
|
|
int hash_len = 0;
|
|
|
|
|
|
|
|
h = Z_ARRVAL_P(args);
|
2012-06-14 16:07:12 +02:00
|
|
|
hash_len = zend_hash_num_elements(h)+1;
|
|
|
|
command_args = ecalloc(hash_len+1, sizeof(char**));
|
|
|
|
command_args[0] = options.cwd;
|
|
|
|
for (zend_hash_internal_pointer_reset_ex(h, &pos);
|
|
|
|
(key_type = zend_hash_get_current_key_ex(h, &key, &key_len, &key_index, 0, &pos)) != HASH_KEY_NON_EXISTANT;
|
|
|
|
zend_hash_move_forward_ex(h, &pos)) {
|
|
|
|
|
|
|
|
zval **value;
|
|
|
|
|
|
|
|
zend_hash_get_current_data_ex(h, (void *) &value, &pos);
|
|
|
|
command_args[pos->h+1] = Z_STRVAL_PP(value);
|
|
|
|
}
|
|
|
|
command_args[hash_len] = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
proc = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
PHP_UV_INIT_ZVALS(proc);
|
|
|
|
proc->proc_close_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
2012-06-14 17:18:05 +02:00
|
|
|
TSRMLS_SET_CTX(proc->thread_ctx);
|
2012-06-13 12:42:12 +02:00
|
|
|
|
2012-06-14 15:24:19 +02:00
|
|
|
options.file = command;
|
2012-06-14 16:07:12 +02:00
|
|
|
if (command_args) {
|
|
|
|
options.args = command_args;
|
|
|
|
}
|
2012-06-14 15:24:19 +02:00
|
|
|
options.exit_cb = php_uv_process_close_cb;
|
|
|
|
|
|
|
|
proc->type = IS_UV_PROCESS;
|
|
|
|
proc->uv.process.data = proc;
|
2012-06-15 16:29:36 +02:00
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, proc, uv_resource_handle);
|
|
|
|
proc->resource_id = Z_LVAL_P(return_value);
|
2012-06-14 15:24:19 +02:00
|
|
|
zval_copy_ctor(return_value);
|
|
|
|
|
|
|
|
uv_spawn(loop, &proc->uv.process, options);
|
2012-06-24 18:29:22 +02:00
|
|
|
|
2012-06-15 15:47:46 +02:00
|
|
|
if (zenv!=NULL) {
|
|
|
|
char **p = zenv;
|
|
|
|
while(*p != NULL) {
|
|
|
|
efree(*p);
|
|
|
|
p++;
|
|
|
|
}
|
|
|
|
efree(zenv);
|
|
|
|
}
|
2012-06-14 16:07:12 +02:00
|
|
|
if (command_args) {
|
|
|
|
efree(command_args);
|
|
|
|
}
|
2012-06-13 12:42:12 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-15 16:29:36 +02:00
|
|
|
/* {{{ TODO: */
|
|
|
|
PHP_FUNCTION(uv_process_kill)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle;
|
|
|
|
int signal;
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zl", &handle, &signal) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
uv_process_kill(&uv->uv.process, signal);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_kill)
|
|
|
|
{
|
|
|
|
long pid, signal;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"ll", &pid, &signal) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
uv_kill(pid, signal);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-16 09:48:13 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_chdir)
|
|
|
|
{
|
|
|
|
uv_err_t error;
|
|
|
|
char *directory;
|
|
|
|
int directory_len;
|
|
|
|
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"s", &directory, &directory_len) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
error = uv_chdir(directory);
|
|
|
|
if (error.code == UV_OK) {
|
|
|
|
RETURN_TRUE;
|
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-16 10:22:29 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_init)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-16 10:22:29 +02:00
|
|
|
int error;
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
lock = emalloc(sizeof(php_uv_lock_t));
|
|
|
|
error = uv_rwlock_init(&lock->lock.rwlock);
|
2012-06-16 10:22:29 +02:00
|
|
|
if (error == 0) {
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_REGISTER_RESOURCE(return_value, lock, uv_lock_handle);
|
2012-06-30 07:42:06 +02:00
|
|
|
lock->type = IS_UV_RWLOCK;
|
2012-06-16 10:22:29 +02:00
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-16 10:37:57 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_rdlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-16 10:37:57 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
lock->locked = 0x01;
|
|
|
|
uv_rwlock_rdlock(&lock->lock.rwlock);
|
2012-06-16 10:37:57 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_tryrdlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-16 10:37:57 +02:00
|
|
|
zval *handle;
|
2012-06-30 07:10:58 +02:00
|
|
|
int error = 0;
|
2012-06-16 10:37:57 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
error = uv_rwlock_tryrdlock(&lock->lock.rwlock);
|
|
|
|
if (error == 0) {
|
|
|
|
lock->locked = 0x01;
|
|
|
|
RETURN_TRUE;
|
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
2012-06-16 10:37:57 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_rdunlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-16 10:37:57 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
if (lock->locked == 0x01) {
|
|
|
|
uv_rwlock_rdunlock(&lock->lock.rwlock);
|
|
|
|
lock->locked = 0x00;
|
|
|
|
}
|
2012-06-16 10:37:57 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_wrlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-16 10:37:57 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
lock->locked = 0x02;
|
|
|
|
uv_rwlock_wrlock(&lock->lock.rwlock);
|
2012-06-16 10:37:57 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-17 14:11:16 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_trywrlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-17 14:11:16 +02:00
|
|
|
zval *handle;
|
2012-06-30 07:10:58 +02:00
|
|
|
int error = 0;
|
2012-06-17 14:11:16 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
error = uv_rwlock_trywrlock(&lock->lock.rwlock);
|
|
|
|
if (error == 0) {
|
|
|
|
lock->locked = 0x02;
|
|
|
|
RETURN_TRUE;
|
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
2012-06-17 14:11:16 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_rwlock_wrunlock)
|
|
|
|
{
|
2012-06-30 07:10:58 +02:00
|
|
|
php_uv_lock_t *lock;
|
2012-06-17 14:11:16 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:10:58 +02:00
|
|
|
ZEND_FETCH_RESOURCE(lock, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
if (lock->locked == 0x02) {
|
|
|
|
uv_rwlock_wrunlock(&lock->lock.rwlock);
|
|
|
|
lock->locked = 0x00;
|
|
|
|
}
|
2012-06-17 14:11:16 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-16 10:37:57 +02:00
|
|
|
|
2012-06-17 14:18:30 +02:00
|
|
|
|
2012-06-30 09:31:19 +02:00
|
|
|
/* {{{ proto uv_lock uv_mutex_init(void) */
|
2012-06-17 14:18:30 +02:00
|
|
|
PHP_FUNCTION(uv_mutex_init)
|
|
|
|
{
|
2012-06-30 07:42:06 +02:00
|
|
|
php_uv_lock_t *mutex;
|
2012-06-17 14:18:30 +02:00
|
|
|
int error;
|
|
|
|
|
2012-06-30 07:42:06 +02:00
|
|
|
mutex = emalloc(sizeof(php_uv_t));
|
|
|
|
error = uv_mutex_init(&mutex->lock.mutex);
|
2012-06-17 14:18:30 +02:00
|
|
|
if (error == 0) {
|
2012-06-30 07:42:06 +02:00
|
|
|
ZEND_REGISTER_RESOURCE(return_value, mutex, uv_lock_handle);
|
|
|
|
mutex->type = IS_UV_MUTEX;
|
2012-06-17 14:18:30 +02:00
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-30 09:31:19 +02:00
|
|
|
/* {{{ proto void uv_mutex_lock(uv_lock $lock)*/
|
2012-06-17 14:18:30 +02:00
|
|
|
PHP_FUNCTION(uv_mutex_lock)
|
|
|
|
{
|
2012-06-30 07:42:06 +02:00
|
|
|
php_uv_lock_t *mutex;
|
2012-06-17 14:18:30 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:42:06 +02:00
|
|
|
ZEND_FETCH_RESOURCE(mutex, php_uv_lock_t*, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
uv_mutex_lock(&mutex->lock.mutex);
|
|
|
|
mutex->locked = 0x01;
|
2012-06-17 14:18:30 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-30 09:31:19 +02:00
|
|
|
/* {{{ proto: bool uv_mutex_trylock(uv_lock $lock) */
|
2012-06-17 14:18:30 +02:00
|
|
|
PHP_FUNCTION(uv_mutex_trylock)
|
|
|
|
{
|
2012-06-30 07:42:06 +02:00
|
|
|
php_uv_lock_t *mutex;
|
2012-06-17 14:18:30 +02:00
|
|
|
zval *handle;
|
2012-06-30 07:42:06 +02:00
|
|
|
int error = 0;
|
2012-06-17 14:18:30 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:42:06 +02:00
|
|
|
ZEND_FETCH_RESOURCE(mutex, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
error = uv_mutex_trylock(&mutex->lock.mutex);
|
|
|
|
|
|
|
|
if (error == 0) {
|
|
|
|
mutex->locked = 0x01;
|
|
|
|
RETURN_TRUE;
|
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
2012-06-17 14:18:30 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-30 09:31:19 +02:00
|
|
|
/* {{{ void uv_mutex_unlock(uv_lock $lock) */
|
2012-06-17 14:18:30 +02:00
|
|
|
PHP_FUNCTION(uv_mutex_unlock)
|
|
|
|
{
|
2012-06-30 07:42:06 +02:00
|
|
|
php_uv_lock_t *mutex;
|
2012-06-17 14:18:30 +02:00
|
|
|
zval *handle;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-30 07:42:06 +02:00
|
|
|
ZEND_FETCH_RESOURCE(mutex, php_uv_lock_t *, &handle, -1, PHP_UV_LOCK_RESOURCE_NAME, uv_lock_handle);
|
|
|
|
if (mutex->locked == 0x01) {
|
|
|
|
uv_mutex_unlock(&mutex->lock.mutex);
|
|
|
|
mutex->locked = 0x00;
|
|
|
|
}
|
2012-06-17 14:18:30 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-17 15:50:18 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_prepare_init)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *zloop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|z",&zloop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_prepare_init emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_PREPARE;
|
|
|
|
r = uv_prepare_init(loop, &uv->uv.prepare);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_prepare_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->uv.prepare.data = uv;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_prepare_start)
|
|
|
|
{
|
|
|
|
zval *handle, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_prepare_start\n");
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-17 15:50:18 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rz",&handle, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
uv->prepare_cb = callback;
|
|
|
|
if(uv->type == IS_UV_PREPARE) {
|
2012-06-17 16:04:54 +02:00
|
|
|
uv->uv.prepare.data = uv;
|
2012-06-17 15:50:18 +02:00
|
|
|
} else {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "this type does not support yet");
|
|
|
|
}
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
r = uv_prepare_start((uv_prepare_t*)php_uv_get_current_stream(uv), php_uv_prepare_cb);
|
2012-06-17 15:50:18 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "read failed");
|
|
|
|
}
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_prepare_start, uv->resource_id);
|
2012-06-17 15:50:18 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_prepare_stop)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-25 18:04:16 +02:00
|
|
|
uv_prepare_stop((uv_prepare_t*)php_uv_get_current_stream(uv));
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_prepare_stop, uv->resource_id);
|
2012-06-17 15:50:18 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-17 16:04:54 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_check_init)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *zloop = NULL;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|z",&zloop) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_check_init emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_CHECK;
|
|
|
|
r = uv_check_init(loop, &uv->uv.check);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_check_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->uv.check.data = uv;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_check_start)
|
|
|
|
{
|
|
|
|
zval *handle, *callback;
|
|
|
|
php_uv_t *uv;
|
|
|
|
int r;
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_PRINT("uv_check_start");
|
2012-06-18 15:32:15 +02:00
|
|
|
|
2012-06-17 16:04:54 +02:00
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rz",&handle, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
zend_list_addref(uv->resource_id);
|
|
|
|
|
|
|
|
uv->check_cb = callback;
|
|
|
|
if(uv->type == IS_UV_CHECK) {
|
|
|
|
uv->uv.check.data = uv;
|
|
|
|
} else {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "this type does not support yet");
|
|
|
|
}
|
|
|
|
|
2012-06-25 18:04:16 +02:00
|
|
|
r = uv_check_start((uv_check_t*)php_uv_get_current_stream(uv), php_uv_check_cb);
|
2012-06-17 16:04:54 +02:00
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "read failed");
|
|
|
|
}
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_check_start, uv->resource_id);
|
2012-06-17 16:04:54 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_check_stop)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-25 18:04:16 +02:00
|
|
|
uv_check_stop((uv_check_t*)php_uv_get_current_stream(uv));
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_check_stop, uv->resource_id);
|
2012-06-17 16:04:54 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-17 15:50:18 +02:00
|
|
|
|
|
|
|
|
2012-06-17 16:18:33 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_async_init)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *zloop = NULL;
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *callback;
|
2012-06-17 16:18:33 +02:00
|
|
|
uv_loop_t *loop;
|
2012-06-18 15:32:15 +02:00
|
|
|
php_uv_t *uv;
|
2012-06-17 16:18:33 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zz",&zloop, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_check_init emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_ASYNC;
|
|
|
|
r = uv_async_init(loop, &uv->uv.async, php_uv_async_cb);
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_async_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->uv.async.data = uv;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
uv->async_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_async_send)
|
|
|
|
{
|
|
|
|
zval *handle;
|
|
|
|
php_uv_t *uv;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"r", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t *, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-25 18:04:16 +02:00
|
|
|
uv_async_send((uv_async_t*)php_uv_get_current_stream(uv));
|
2012-06-29 17:58:20 +02:00
|
|
|
PHP_UV_DEBUG_RESOURCE_REFCOUNT(uv_async_send, uv->resource_id);
|
2012-06-17 16:18:33 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-17 18:32:50 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_queue_work)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *zloop = NULL;
|
2012-06-18 15:32:15 +02:00
|
|
|
zval *callback, *after_callback;
|
2012-06-17 18:32:50 +02:00
|
|
|
uv_loop_t *loop;
|
2012-06-18 15:32:15 +02:00
|
|
|
php_uv_t *uv;
|
2012-06-17 18:32:50 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zzz",&zloop, &callback, &after_callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_queue_work emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_WORK;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
|
|
|
|
uv->work_cb = callback;
|
|
|
|
uv->after_work_cb = after_callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
Z_ADDREF_P(after_callback);
|
|
|
|
uv->uv.work.data = uv;
|
|
|
|
|
|
|
|
r = uv_queue_work(loop, (uv_work_t*)&uv->uv.work, php_uv_work_cb, php_uv_after_work_cb);
|
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_async_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(return_value);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-17 16:18:33 +02:00
|
|
|
|
2012-06-20 05:40:39 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_open)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *tmp, *zloop = NULL;
|
|
|
|
zval *callback;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len;
|
|
|
|
long flag, mode;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsllz", &zloop, &path, &path_len, &flag, &mode, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_queue_work emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_FS;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
r = uv_fs_open(loop, (uv_fs_t*)&uv->uv.fs, path, flag, mode, php_uv_fs_cb);
|
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_async_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
ZEND_REGISTER_RESOURCE(tmp, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(tmp);
|
|
|
|
Z_TYPE_P(tmp) = IS_NULL;
|
|
|
|
zval_ptr_dtor(&tmp);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_read)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *tmp, *zloop = NULL;
|
|
|
|
zval *callback;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
2012-06-21 02:43:20 +02:00
|
|
|
unsigned long fd;
|
2012-06-20 05:40:39 +02:00
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
2012-06-21 02:43:20 +02:00
|
|
|
"zlz", &zloop, &fd, &callback) == FAILURE) {
|
2012-06-20 05:40:39 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_queue_work emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_FS;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
//uv_fs_read($loop, int $fd, Closure $cb)
|
|
|
|
//UV_EXTERN int uv_fs_read(uv_loop_t* loop, uv_fs_t* req, uv_file file, void* buf, size_t length, off_t offset, uv_fs_cb cb);
|
2012-06-21 02:43:20 +02:00
|
|
|
memset(uv_fs_read_buf, 0, sizeof(uv_fs_read_buf));
|
|
|
|
r = uv_fs_read(loop, (uv_fs_t*)&uv->uv.fs, fd, uv_fs_read_buf, sizeof(uv_fs_read_buf), -1, php_uv_fs_cb);
|
2012-06-20 05:40:39 +02:00
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_async_init failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
ZEND_REGISTER_RESOURCE(tmp, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(tmp);
|
|
|
|
Z_TYPE_P(tmp) = IS_NULL;
|
|
|
|
zval_ptr_dtor(&tmp);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-22 05:13:11 +02:00
|
|
|
//* UV_EXTERN int uv_fs_close(uv_loop_t* loop, uv_fs_t* req, uv_file file,uv_fs_cb cb);
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_close)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *tmp, *zloop = NULL;
|
|
|
|
zval *callback;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlz", &zloop, &fd, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_queue_work emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_FS;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
//uv_fs_read($loop, int $fd, Closure $cb)
|
|
|
|
//UV_EXTERN int uv_fs_read(uv_loop_t* loop, uv_fs_t* req, uv_file file, void* buf, size_t length, off_t offset, uv_fs_cb cb);
|
|
|
|
memset(uv_fs_read_buf, 0, sizeof(uv_fs_read_buf));
|
|
|
|
r = uv_fs_close(loop, (uv_fs_t*)&uv->uv.fs, fd, php_uv_fs_cb);
|
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_fs_close failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
ZEND_REGISTER_RESOURCE(tmp, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(tmp);
|
|
|
|
Z_TYPE_P(tmp) = IS_NULL;
|
|
|
|
zval_ptr_dtor(&tmp);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-22 05:51:16 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_write)
|
|
|
|
{
|
|
|
|
int r;
|
|
|
|
zval *tmp, *zloop = NULL;
|
|
|
|
zval *callback;
|
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *buffer;
|
|
|
|
int buffer_len = 0;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlsz", &zloop, &fd, &buffer, &buffer_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
uv = (php_uv_t *)emalloc(sizeof(php_uv_t));
|
|
|
|
if (!uv) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_fs_write emalloc failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (zloop != NULL) {
|
|
|
|
ZEND_FETCH_RESOURCE(loop, uv_loop_t*, &zloop, -1, PHP_UV_LOOP_RESOURCE_NAME, uv_loop_handle);
|
|
|
|
} else {
|
|
|
|
loop = uv_default_loop();
|
|
|
|
}
|
|
|
|
|
|
|
|
uv->type = IS_UV_FS;
|
|
|
|
PHP_UV_INIT_ZVALS(uv)
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
uv->buffer = estrndup(buffer, buffer_len);
|
|
|
|
|
|
|
|
//* UV_EXTERN int uv_fs_write(uv_loop_t* loop, uv_fs_t* req, uv_file file,void* buf, size_t length, off_t offset, uv_fs_cb cb);
|
|
|
|
r = uv_fs_write(loop, (uv_fs_t*)&uv->uv.fs, fd, uv->buffer, buffer_len, -1, php_uv_fs_cb);
|
|
|
|
|
|
|
|
if (r) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_fs_write failed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TSRMLS_SET_CTX(uv->thread_ctx);
|
|
|
|
MAKE_STD_ZVAL(tmp);
|
|
|
|
ZEND_REGISTER_RESOURCE(tmp, uv, uv_resource_handle);
|
|
|
|
uv->resource_id = Z_LVAL_P(tmp);
|
|
|
|
Z_TYPE_P(tmp) = IS_NULL;
|
|
|
|
zval_ptr_dtor(&tmp);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 17:59:27 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_fsync)
|
|
|
|
{
|
2012-06-22 18:16:27 +02:00
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 17:59:27 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlz", &zloop, &fd, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-06-22 18:16:27 +02:00
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
2012-06-22 17:59:27 +02:00
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
2012-06-22 18:16:27 +02:00
|
|
|
PHP_UV_FS_ASYNC(loop, fsync, fd);
|
2012-06-22 17:59:27 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 18:19:21 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_fdatasync)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:19:21 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlz", &zloop, &fd, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, fdatasync, fd);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 18:26:44 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_ftruncate)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:26:44 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long offset = 0;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zllz", &zloop, &fd, &offset, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, ftruncate, fd, offset);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-22 18:19:21 +02:00
|
|
|
|
2012-06-22 18:45:00 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_mkdir)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:45:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
long mode = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zslz", &zloop, &path, &path_len, &mode, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, mkdir, path, mode);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_rmdir)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:45:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz", &zloop, &path, &path_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, rmdir, path);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_unlink)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:45:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz", &zloop, &path, &path_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, unlink, path);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-22 17:59:27 +02:00
|
|
|
|
2012-06-22 18:48:29 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_rename)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:48:29 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *from, *to;
|
|
|
|
int from_len, to_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zssz", &zloop, &from, &from_len, &to, &to_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, rename, from, to);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 18:58:00 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_utime)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:58:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long utime, atime;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsllz", &zloop, &path, &path_len, &utime, &atime, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, utime, path, utime, atime);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_futime)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 18:58:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long utime, atime;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlllz", &zloop, &fd, &utime, &atime, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, futime, fd, utime, atime);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 19:03:00 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_chmod)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:03:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long mode;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zslz", &zloop, &path, &path_len, &mode, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, chmod, path, mode);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_fchmod)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:03:00 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long mode;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlllz", &zloop, &fd, &mode, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, fchmod, fd, mode);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
2012-06-22 19:07:56 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_chown)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:07:56 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long uid, gid;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zslz", &zloop, &path, &path_len, &uid, &gid, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
2012-06-22 19:17:41 +02:00
|
|
|
PHP_UV_FS_ASYNC(loop, chown, path, uid, gid);
|
2012-06-22 19:07:56 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
2012-06-22 19:17:41 +02:00
|
|
|
PHP_FUNCTION(uv_fs_fchown)
|
2012-06-22 19:07:56 +02:00
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:07:56 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
2012-06-22 19:17:41 +02:00
|
|
|
long uid, gid;
|
2012-06-22 19:07:56 +02:00
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlllz", &zloop, &fd, &uid, &gid, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
2012-06-22 19:17:41 +02:00
|
|
|
PHP_UV_FS_ASYNC(loop, fchown, fd, uid, gid);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_link)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:17:41 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *from, *to;
|
|
|
|
int from_len, to_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zssz", &zloop, &from, &from_len, &to, &to_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, link, from, to);
|
2012-06-22 19:07:56 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-22 18:48:29 +02:00
|
|
|
|
2012-06-22 19:17:41 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_symlink)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-22 19:17:41 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *from, *to;
|
|
|
|
int from_len, to_len = 0;
|
|
|
|
long flags;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsslz", &zloop, &from, &from_len, &to, &to_len, &flags, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, symlink, from, to, flags);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 04:22:41 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_readlink)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 04:22:41 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz", &zloop, &path, &path_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, readlink, path);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 05:01:10 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_stat)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 05:01:10 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz", &zloop, &path, &path_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, stat, path);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 06:00:27 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_lstat)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 06:00:27 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zsz", &zloop, &path, &path_len, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, lstat, path);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_fstat)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 06:00:27 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zlz", &zloop, &fd, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, fstat, fd);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 06:27:59 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_readdir)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 06:27:59 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
long flags;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zslz", &zloop, &path, &path_len, &flags, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, readdir, path, flags);
|
|
|
|
}
|
|
|
|
/* }}} */
|
2012-06-23 06:40:12 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_sendfile)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 06:40:12 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
unsigned long in_fd, out_fd;
|
|
|
|
long offset, length = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zllllz", &zloop, &in_fd, &out_fd, &offset, &length, &callback) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs.data = uv;
|
|
|
|
|
|
|
|
PHP_UV_FS_ASYNC(loop, sendfile, in_fd, out_fd, offset, length);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 07:18:38 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_fs_event_init)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *callback, *zloop = NULL;
|
2012-06-23 07:18:38 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
char *path;
|
|
|
|
int path_len = 0;
|
|
|
|
long flags = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zszl", &zloop, &path, &path_len, &callback, &flags) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_FS_EVENT);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->fs_event_cb = callback;
|
|
|
|
Z_ADDREF_P(callback);
|
|
|
|
uv->uv.fs_event.data = uv;
|
|
|
|
|
|
|
|
error = uv_fs_event_init(loop, (uv_fs_event_t*)&uv->uv.fs_event, path, php_uv_fs_event_cb, flags); \
|
2012-06-23 08:05:14 +02:00
|
|
|
if (error) {
|
2012-06-23 07:18:38 +02:00
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_fs_event_init failed"); \
|
2012-06-23 08:05:14 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tty_init)
|
|
|
|
{
|
|
|
|
int error;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *zloop = NULL;
|
2012-06-23 08:05:14 +02:00
|
|
|
uv_loop_t *loop;
|
|
|
|
php_uv_t *uv;
|
|
|
|
long readable = 1;
|
|
|
|
unsigned long fd;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zll", &zloop, &fd, &readable) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_UV_INIT_UV(uv, IS_UV_TTY);
|
|
|
|
PHP_UV_FETCH_UV_DEFAULT_LOOP(loop, zloop);
|
|
|
|
|
|
|
|
uv->uv.tty.data = uv;
|
|
|
|
|
|
|
|
error = uv_tty_init(loop, (uv_tty_t*)&uv->uv.tty, fd, readable); \
|
|
|
|
if (error) {
|
|
|
|
php_error_docref(NULL TSRMLS_CC, E_ERROR, "uv_fs_event_init failed"); \
|
|
|
|
return;
|
2012-06-23 07:18:38 +02:00
|
|
|
}
|
2012-06-23 08:05:14 +02:00
|
|
|
|
2012-06-23 07:18:38 +02:00
|
|
|
|
2012-06-23 08:05:14 +02:00
|
|
|
ZVAL_RESOURCE(return_value, uv->resource_id);
|
2012-06-23 07:18:38 +02:00
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 08:05:14 +02:00
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tty_get_winsize)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *handle, *w, *h = NULL;
|
2012-06-23 08:05:14 +02:00
|
|
|
int error, width, height;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zzz", &handle, &w, &h) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
error = uv_tty_get_winsize(&uv->uv.tty, &width, &height);
|
|
|
|
|
|
|
|
ZVAL_LONG(w, width);
|
|
|
|
ZVAL_LONG(h, height);
|
|
|
|
|
|
|
|
RETURN_LONG(error);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tty_set_mode)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
2012-06-24 08:24:42 +02:00
|
|
|
zval *handle;
|
2012-06-23 08:05:14 +02:00
|
|
|
long mode;
|
|
|
|
long error = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zl", &handle, &mode) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-24 08:24:42 +02:00
|
|
|
error = uv_tty_set_mode(&uv->uv.tty, mode);
|
2012-06-23 08:05:14 +02:00
|
|
|
RETURN_LONG(error);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tty_reset_mode)
|
|
|
|
{
|
|
|
|
uv_tty_reset_mode();
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 13:27:30 +02:00
|
|
|
#ifdef PHP_WIN32
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tcp_simultaneous_accepts)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle, *result;
|
|
|
|
long enable;
|
|
|
|
long error = 0;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"zl", &handle, &enable) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
error = uv_tcp_simultaneous_accepts(&uv->uv.tcp, enable);
|
|
|
|
RETURN_LONG(error);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tcp_getsockname)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle, *result;
|
|
|
|
int addr_len, error = 0;
|
|
|
|
struct sockaddr_storage addr;
|
|
|
|
addr_len = sizeof(struct sockaddr_storage);
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
error = uv_tcp_getsockname(&uv->uv.tcp, (struct sockaddr*)&addr, &addr_len);
|
|
|
|
|
|
|
|
result = php_uv_address_to_zval((struct sockaddr*)&addr);
|
|
|
|
RETURN_ZVAL(result, 0, 1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_tcp_getpeername)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle, *result;
|
|
|
|
int addr_len, error = 0;
|
|
|
|
struct sockaddr_storage addr;
|
|
|
|
addr_len = sizeof(struct sockaddr_storage);
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
|
|
|
error = uv_tcp_getpeername(&uv->uv.tcp, (struct sockaddr*)&addr, &addr_len);
|
|
|
|
|
|
|
|
result = php_uv_address_to_zval((struct sockaddr*)&addr);
|
|
|
|
RETURN_ZVAL(result, 0, 1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_udp_getsockname)
|
|
|
|
{
|
|
|
|
php_uv_t *uv;
|
|
|
|
zval *handle, *result;
|
|
|
|
int addr_len, error = 0;
|
|
|
|
struct sockaddr_storage addr;
|
|
|
|
addr_len = sizeof(struct sockaddr_storage);
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z", &handle) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(uv, php_uv_t*, &handle, -1, PHP_UV_RESOURCE_NAME, uv_resource_handle);
|
2012-06-25 18:04:16 +02:00
|
|
|
error = uv_udp_getsockname(&uv->uv.udp, (struct sockaddr*)&addr, &addr_len);
|
2012-06-23 13:27:30 +02:00
|
|
|
|
|
|
|
result = php_uv_address_to_zval((struct sockaddr*)&addr);
|
|
|
|
RETURN_ZVAL(result, 0, 1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-23 08:05:14 +02:00
|
|
|
|
2012-06-23 20:34:06 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_resident_set_memory)
|
|
|
|
{
|
|
|
|
size_t rss;
|
|
|
|
uv_resident_set_memory(&rss);
|
|
|
|
|
|
|
|
RETURN_LONG(rss);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-06-24 08:39:51 +02:00
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_ip4_name)
|
|
|
|
{
|
|
|
|
int error = 0;
|
|
|
|
zval *address;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
char ip[INET6_ADDRSTRLEN];
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&address) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
|
2012-06-25 17:49:16 +02:00
|
|
|
error = uv_ip4_name(&addr->addr.ipv4, ip, INET6_ADDRSTRLEN);
|
2012-06-24 08:39:51 +02:00
|
|
|
RETVAL_STRING(ip,1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
|
|
|
/* {{{ */
|
|
|
|
PHP_FUNCTION(uv_ip6_name)
|
|
|
|
{
|
|
|
|
int error = 0;
|
|
|
|
zval *address;
|
|
|
|
php_uv_sockaddr_t *addr;
|
|
|
|
char ip[INET6_ADDRSTRLEN];
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"z",&address) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(addr, php_uv_sockaddr_t *, &address, -1, PHP_UV_SOCKADDR_RESOURCE_NAME, uv_sockaddr_handle);
|
|
|
|
|
2012-06-25 17:49:16 +02:00
|
|
|
error = uv_ip6_name(&addr->addr.ipv6, ip, INET6_ADDRSTRLEN);
|
2012-06-24 08:39:51 +02:00
|
|
|
RETVAL_STRING(ip,1);
|
|
|
|
}
|
|
|
|
/* }}} */
|
|
|
|
|
2012-07-01 06:15:14 +02:00
|
|
|
/* HTTP PARSER */
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_http_parser_init, 0, 0, 1)
|
|
|
|
ZEND_ARG_INFO(0, target)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_uv_http_parser_execute, 0, 0, 3)
|
|
|
|
ZEND_ARG_INFO(0, resource)
|
|
|
|
ZEND_ARG_INFO(0, buffer)
|
|
|
|
ZEND_ARG_INFO(0, setting)
|
|
|
|
ZEND_END_ARG_INFO()
|
|
|
|
|
|
|
|
PHP_FUNCTION(uv_http_parser_init)
|
|
|
|
{
|
|
|
|
long target = HTTP_REQUEST;
|
|
|
|
php_http_parser_context *ctx;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"|l",&target) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx = emalloc(sizeof(php_http_parser_context));
|
|
|
|
http_parser_init(&ctx->parser, target);
|
|
|
|
|
|
|
|
if (target == HTTP_RESPONSE) {
|
|
|
|
ctx->is_response = 1;
|
|
|
|
} else {
|
|
|
|
ctx->is_response = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
memset(&ctx->handle, 0, sizeof(struct http_parser_url));
|
|
|
|
|
|
|
|
/* setup callback */
|
|
|
|
ctx->settings.on_message_begin = on_message_begin;
|
|
|
|
ctx->settings.on_header_field = header_field_cb;
|
|
|
|
ctx->settings.on_header_value = header_value_cb;
|
|
|
|
ctx->settings.on_url = on_url_cb;
|
|
|
|
ctx->settings.on_body = on_body_cb;
|
|
|
|
ctx->settings.on_headers_complete = on_headers_complete;
|
|
|
|
ctx->settings.on_message_complete = on_message_complete;
|
|
|
|
|
|
|
|
|
|
|
|
ZEND_REGISTER_RESOURCE(return_value, ctx, uv_httpparser_handle);
|
|
|
|
}
|
|
|
|
|
|
|
|
PHP_FUNCTION(uv_http_parser_execute)
|
|
|
|
{
|
|
|
|
zval *z_parser,*result, *headers;
|
|
|
|
php_http_parser_context *context;
|
|
|
|
char *body;
|
|
|
|
int body_len;
|
|
|
|
|
|
|
|
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC,
|
|
|
|
"rs/a",&z_parser, &body, &body_len, &result) == FAILURE) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ZEND_FETCH_RESOURCE(context, php_http_parser_context*, &z_parser, -1, PHP_UV_HTTPPARSER_RESOURCE_NAME, uv_httpparser_handle);
|
|
|
|
|
|
|
|
MAKE_STD_ZVAL(headers);
|
|
|
|
array_init(headers);
|
|
|
|
add_assoc_zval(result, "headers", headers);
|
|
|
|
|
|
|
|
context->headers = headers;
|
|
|
|
context->data = result;
|
|
|
|
context->parser.data = context;
|
|
|
|
|
|
|
|
http_parser_execute(&context->parser, &context->settings, body, body_len);
|
|
|
|
|
|
|
|
if (context->is_response == 0) {
|
|
|
|
add_assoc_string(result, "REQUEST_METHOD", (char*)http_method_str(context->parser.method), 1);
|
|
|
|
} else {
|
|
|
|
add_assoc_long(result, "status_code", (long)context->parser.status_code);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (context->finished == 1) {
|
|
|
|
RETURN_TRUE;
|
|
|
|
} else {
|
|
|
|
RETURN_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-05-23 06:35:28 +02:00
|
|
|
static zend_function_entry uv_functions[] = {
|
2012-05-29 00:31:25 +02:00
|
|
|
/* general */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_update_time, arginfo_uv_update_time)
|
|
|
|
PHP_FE(uv_ref, arginfo_uv_ref)
|
|
|
|
PHP_FE(uv_unref, arginfo_uv_unref)
|
|
|
|
PHP_FE(uv_default_loop, NULL)
|
|
|
|
PHP_FE(uv_run, arginfo_uv_run)
|
|
|
|
PHP_FE(uv_run_once, arginfo_uv_run_once)
|
|
|
|
PHP_FE(uv_ip4_addr, arginfo_uv_ip4_addr)
|
|
|
|
PHP_FE(uv_ip6_addr, arginfo_uv_ip6_addr)
|
2012-06-28 15:33:10 +02:00
|
|
|
PHP_FE(uv_ip4_name, arginfo_uv_ip4_name)
|
|
|
|
PHP_FE(uv_ip6_name, arginfo_uv_ip6_name)
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_write, arginfo_uv_write)
|
2012-06-30 18:55:48 +02:00
|
|
|
PHP_FE(uv_shutdown, arginfo_uv_shutdown)
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_close, arginfo_uv_close)
|
|
|
|
PHP_FE(uv_now, arginfo_uv_now)
|
|
|
|
PHP_FE(uv_loop_delete, arginfo_uv_loop_delete)
|
|
|
|
PHP_FE(uv_read_start, arginfo_uv_read_start)
|
2012-07-01 01:25:16 +02:00
|
|
|
PHP_FE(uv_read2_start, arginfo_uv_read2_start)
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_read_stop, arginfo_uv_read_stop)
|
|
|
|
PHP_FE(uv_last_error, arginfo_uv_last_error)
|
|
|
|
PHP_FE(uv_err_name, arginfo_uv_err_name)
|
|
|
|
PHP_FE(uv_strerror, arginfo_uv_strerror)
|
|
|
|
PHP_FE(uv_is_active, arginfo_uv_is_active)
|
|
|
|
PHP_FE(uv_is_readable, arginfo_uv_is_readable)
|
|
|
|
PHP_FE(uv_is_writable, arginfo_uv_is_writable)
|
2012-05-29 00:31:25 +02:00
|
|
|
/* idle */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_idle_init, arginfo_uv_idle_init)
|
|
|
|
PHP_FE(uv_idle_start, arginfo_uv_idle_start)
|
|
|
|
PHP_FE(uv_idle_stop, arginfo_uv_idle_stop)
|
2012-05-29 00:31:25 +02:00
|
|
|
/* timer */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_timer_init, arginfo_uv_timer_init)
|
|
|
|
PHP_FE(uv_timer_start, arginfo_uv_timer_start)
|
|
|
|
PHP_FE(uv_timer_stop, arginfo_uv_timer_stop)
|
|
|
|
PHP_FE(uv_timer_again, arginfo_uv_timer_again)
|
|
|
|
PHP_FE(uv_timer_set_repeat, arginfo_uv_timer_set_repeat)
|
|
|
|
PHP_FE(uv_timer_get_repeat, arginfo_uv_timer_get_repeat)
|
2012-05-29 00:31:25 +02:00
|
|
|
/* tcp */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_tcp_init, arginfo_uv_tcp_init)
|
|
|
|
PHP_FE(uv_tcp_nodelay, arginfo_uv_tcp_nodelay)
|
|
|
|
PHP_FE(uv_tcp_bind, arginfo_uv_tcp_bind)
|
|
|
|
PHP_FE(uv_tcp_bind6, arginfo_uv_tcp_bind6)
|
|
|
|
PHP_FE(uv_listen, arginfo_uv_listen)
|
|
|
|
PHP_FE(uv_accept, arginfo_uv_accept)
|
|
|
|
PHP_FE(uv_tcp_connect, arginfo_uv_tcp_connect)
|
|
|
|
PHP_FE(uv_tcp_connect6, arginfo_uv_tcp_connect6)
|
2012-05-29 18:47:30 +02:00
|
|
|
/* udp */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_udp_init, arginfo_uv_udp_init)
|
|
|
|
PHP_FE(uv_udp_bind, arginfo_uv_udp_bind)
|
|
|
|
PHP_FE(uv_udp_bind6, arginfo_uv_udp_bind6)
|
|
|
|
PHP_FE(uv_udp_set_multicast_loop, arginfo_uv_udp_set_multicast_loop)
|
|
|
|
PHP_FE(uv_udp_set_multicast_ttl, arginfo_uv_udp_set_multicast_ttl)
|
|
|
|
PHP_FE(uv_udp_send, arginfo_uv_udp_send)
|
|
|
|
PHP_FE(uv_udp_recv_start, arginfo_uv_udp_recv_start)
|
|
|
|
PHP_FE(uv_udp_recv_stop, arginfo_uv_udp_recv_stop)
|
2012-06-28 15:33:10 +02:00
|
|
|
PHP_FE(uv_udp_set_membership, arginfo_uv_udp_set_membership)
|
2012-06-23 13:27:30 +02:00
|
|
|
/* other network functions */
|
2012-06-28 15:33:10 +02:00
|
|
|
PHP_FE(uv_tcp_getsockname, arginfo_uv_tcp_getsockname)
|
|
|
|
PHP_FE(uv_tcp_getpeername, arginfo_uv_tcp_getpeername)
|
|
|
|
PHP_FE(uv_udp_getsockname, arginfo_uv_udp_getsockname)
|
2012-06-23 13:27:30 +02:00
|
|
|
#ifdef PHP_WIN32
|
|
|
|
PHP_FE(uv_tcp_simultaneous_accepts, NULL)
|
|
|
|
#endif
|
2012-06-24 17:28:31 +02:00
|
|
|
/* pipe */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_pipe_init, arginfo_uv_pipe_init)
|
|
|
|
PHP_FE(uv_pipe_bind, arginfo_uv_pipe_bind)
|
|
|
|
PHP_FE(uv_pipe_open, arginfo_uv_pipe_open)
|
|
|
|
PHP_FE(uv_pipe_connect, arginfo_uv_pipe_connect)
|
|
|
|
PHP_FE(uv_pipe_pending_instances, arginfo_uv_pipe_pending_instances)
|
2012-06-13 12:42:12 +02:00
|
|
|
/* spawn */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_spawn, arginfo_uv_spawn)
|
|
|
|
PHP_FE(uv_process_kill, arginfo_uv_process_kill)
|
|
|
|
PHP_FE(uv_kill, arginfo_uv_kill)
|
2012-05-28 18:12:09 +02:00
|
|
|
/* c-ares */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_getaddrinfo, arginfo_uv_tcp_connect)
|
2012-06-28 15:33:10 +02:00
|
|
|
PHP_FE(uv_ares_init_options, arginfo_uv_ares_init_options)
|
|
|
|
PHP_FE(ares_gethostbyname, arginfo_ares_gethostbyname)
|
2012-06-16 10:22:29 +02:00
|
|
|
/* rwlock */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_rwlock_init, NULL)
|
2012-06-26 18:32:56 +02:00
|
|
|
PHP_FE(uv_rwlock_rdlock, arginfo_uv_rwlock_rdlock)
|
|
|
|
PHP_FE(uv_rwlock_tryrdlock, arginfo_uv_rwlock_tryrdlock)
|
|
|
|
PHP_FE(uv_rwlock_rdunlock, arginfo_uv_rwlock_rdunlock)
|
|
|
|
PHP_FE(uv_rwlock_wrlock, arginfo_uv_rwlock_wrlock)
|
|
|
|
PHP_FE(uv_rwlock_trywrlock, arginfo_uv_rwlock_trywrlock)
|
|
|
|
PHP_FE(uv_rwlock_wrunlock, arginfo_uv_rwlock_wrunlock)
|
2012-06-17 14:18:30 +02:00
|
|
|
/* mutex */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_mutex_init, NULL)
|
2012-06-26 18:32:56 +02:00
|
|
|
PHP_FE(uv_mutex_lock, arginfo_uv_mutex_lock)
|
|
|
|
PHP_FE(uv_mutex_trylock, arginfo_uv_mutex_trylock)
|
|
|
|
PHP_FE(uv_mutex_unlock, arginfo_uv_mutex_unlock)
|
2012-06-17 16:04:54 +02:00
|
|
|
/* prepare (before poll hook) */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_prepare_init, NULL)
|
2012-06-26 18:32:56 +02:00
|
|
|
PHP_FE(uv_prepare_start, arginfo_uv_prepare_start)
|
|
|
|
PHP_FE(uv_prepare_stop, arginfo_uv_prepare_stop)
|
2012-06-17 16:04:54 +02:00
|
|
|
/* check (after poll hook) */
|
2012-06-26 18:32:56 +02:00
|
|
|
PHP_FE(uv_check_init, arginfo_uv_check_init)
|
|
|
|
PHP_FE(uv_check_start, arginfo_uv_check_start)
|
|
|
|
PHP_FE(uv_check_stop, arginfo_uv_check_stop)
|
2012-06-17 16:18:33 +02:00
|
|
|
/* async */
|
2012-06-26 18:32:56 +02:00
|
|
|
PHP_FE(uv_async_init, arginfo_uv_async_init)
|
|
|
|
PHP_FE(uv_async_send, arginfo_uv_async_send)
|
2012-06-20 05:40:39 +02:00
|
|
|
/* queue (does not work yet) */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_queue_work, NULL)
|
2012-06-20 05:40:39 +02:00
|
|
|
/* fs */
|
2012-06-26 18:03:34 +02:00
|
|
|
PHP_FE(uv_fs_open, arginfo_uv_fs_open)
|
|
|
|
PHP_FE(uv_fs_read, arginfo_uv_fs_read)
|
|
|
|
PHP_FE(uv_fs_write, arginfo_uv_fs_write)
|
|
|
|
PHP_FE(uv_fs_close, arginfo_uv_fs_close)
|
|
|
|
PHP_FE(uv_fs_fsync, arginfo_uv_fs_fsync)
|
|
|
|
PHP_FE(uv_fs_fdatasync, arginfo_uv_fs_ftruncate)
|
|
|
|
PHP_FE(uv_fs_ftruncate, arginfo_uv_fs_ftruncate)
|
|
|
|
PHP_FE(uv_fs_mkdir, arginfo_uv_fs_mkdir)
|
|
|
|
PHP_FE(uv_fs_rmdir, arginfo_uv_fs_rmdir)
|
|
|
|
PHP_FE(uv_fs_unlink, arginfo_uv_fs_unlink)
|
|
|
|
PHP_FE(uv_fs_rename, arginfo_uv_fs_rename)
|
|
|
|
PHP_FE(uv_fs_utime, arginfo_uv_fs_utime)
|
|
|
|
PHP_FE(uv_fs_futime, arginfo_uv_fs_futime)
|
|
|
|
PHP_FE(uv_fs_chmod, arginfo_uv_fs_chmod)
|
|
|
|
PHP_FE(uv_fs_fchmod, arginfo_uv_fs_fchmod)
|
|
|
|
PHP_FE(uv_fs_chown, arginfo_uv_fs_chown)
|
|
|
|
PHP_FE(uv_fs_fchown, arginfo_uv_fs_fchown)
|
|
|
|
PHP_FE(uv_fs_link, arginfo_uv_fs_link)
|
|
|
|
PHP_FE(uv_fs_symlink, arginfo_uv_fs_symlink)
|
|
|
|
PHP_FE(uv_fs_readlink, arginfo_uv_fs_readlink)
|
|
|
|
PHP_FE(uv_fs_stat, arginfo_uv_fs_stat)
|
|
|
|
PHP_FE(uv_fs_lstat, arginfo_uv_fs_lstat)
|
|
|
|
PHP_FE(uv_fs_fstat, arginfo_uv_fs_fstat)
|
|
|
|
PHP_FE(uv_fs_readdir, arginfo_uv_fs_readdir)
|
|
|
|
PHP_FE(uv_fs_sendfile, arginfo_uv_fs_sendfile)
|
|
|
|
PHP_FE(uv_fs_event_init, arginfo_uv_fs_event_init)
|
2012-06-23 08:05:14 +02:00
|
|
|
/* tty */
|
2012-06-26 18:03:34 +02:00
|
|
|
PHP_FE(uv_tty_init, arginfo_uv_tty_init)
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_tty_get_winsize, arginfo_uv_tty_get_winsize)
|
|
|
|
PHP_FE(uv_tty_set_mode, NULL)
|
|
|
|
PHP_FE(uv_tty_reset_mode, NULL)
|
2012-06-04 18:12:13 +02:00
|
|
|
/* info */
|
2012-06-24 17:35:48 +02:00
|
|
|
PHP_FE(uv_loadavg, NULL)
|
|
|
|
PHP_FE(uv_uptime, NULL)
|
|
|
|
PHP_FE(uv_cpu_info, NULL)
|
|
|
|
PHP_FE(uv_interface_addresses, NULL)
|
|
|
|
PHP_FE(uv_get_free_memory, NULL)
|
|
|
|
PHP_FE(uv_get_total_memory, NULL)
|
|
|
|
PHP_FE(uv_hrtime, NULL)
|
|
|
|
PHP_FE(uv_exepath, NULL)
|
|
|
|
PHP_FE(uv_cwd, NULL)
|
|
|
|
PHP_FE(uv_chdir, arginfo_uv_chdir)
|
|
|
|
PHP_FE(uv_resident_set_memory, NULL)
|
2012-07-01 06:15:14 +02:00
|
|
|
/* http parser */
|
|
|
|
PHP_FE(uv_http_parser_init, arginfo_uv_http_parser_init)
|
|
|
|
PHP_FE(uv_http_parser_execute, arginfo_uv_http_parser_execute)
|
2012-05-23 06:35:28 +02:00
|
|
|
{NULL, NULL, NULL}
|
|
|
|
};
|
|
|
|
|
2012-05-22 19:43:11 +02:00
|
|
|
|
|
|
|
PHP_MINFO_FUNCTION(uv)
|
|
|
|
{
|
2012-06-24 17:28:31 +02:00
|
|
|
char uv_version[20];
|
|
|
|
sprintf(uv_version, "%d.%d",UV_VERSION_MAJOR, UV_VERSION_MINOR);
|
|
|
|
|
2012-05-22 19:43:11 +02:00
|
|
|
php_printf("PHP libuv Extension\n");
|
2012-06-24 17:28:31 +02:00
|
|
|
php_info_print_table_start();
|
|
|
|
php_info_print_table_header(2,"libuv Support", "enabled");
|
|
|
|
php_info_print_table_row(2,"Version", PHP_UV_EXTVER);
|
|
|
|
php_info_print_table_row(2,"bundled libuv Version", uv_version);
|
|
|
|
php_info_print_table_end();
|
2012-05-22 19:43:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
zend_module_entry uv_module_entry = {
|
|
|
|
#if ZEND_MODULE_API_NO >= 20010901
|
|
|
|
STANDARD_MODULE_HEADER,
|
|
|
|
#endif
|
|
|
|
"uv",
|
2012-05-23 06:35:28 +02:00
|
|
|
uv_functions, /* Functions */
|
2012-05-22 19:43:11 +02:00
|
|
|
PHP_MINIT(uv), /* MINIT */
|
|
|
|
NULL, /* MSHUTDOWN */
|
|
|
|
NULL, /* RINIT */
|
|
|
|
NULL, /* RSHUTDOWN */
|
|
|
|
PHP_MINFO(uv), /* MINFO */
|
|
|
|
#if ZEND_MODULE_API_NO >= 20010901
|
|
|
|
PHP_UV_EXTVER,
|
|
|
|
#endif
|
|
|
|
STANDARD_MODULE_PROPERTIES
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef COMPILE_DL_UV
|
|
|
|
ZEND_GET_MODULE(uv)
|
|
|
|
#endif
|