diff options
-rw-r--r-- | ext/posix/posix.c | 135 |
1 files changed, 74 insertions, 61 deletions
diff --git a/ext/posix/posix.c b/ext/posix/posix.c index 771e316325..2d1e300a47 100644 --- a/ext/posix/posix.c +++ b/ext/posix/posix.c @@ -442,7 +442,9 @@ ZEND_GET_MODULE(posix) #define PHP_POSIX_SINGLE_ARG_FUNC(func_name) \ zend_long val; \ - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &val) == FAILURE) RETURN_FALSE; \ + ZEND_PARSE_PARAMETERS_START(1, 1) \ + Z_PARAM_LONG(val) \ + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); \ if (func_name(val) < 0) { \ POSIX_G(last_error) = errno; \ RETURN_FALSE; \ @@ -456,9 +458,10 @@ PHP_FUNCTION(posix_kill) { zend_long pid, sig; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ll", &pid, &sig) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(2, 2) + Z_PARAM_LONG(pid) + Z_PARAM_LONG(sig) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); if (kill(pid, sig) < 0) { POSIX_G(last_error) = errno; @@ -621,9 +624,10 @@ PHP_FUNCTION(posix_setpgid) { zend_long pid, pgid; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ll", &pid, &pgid) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(2, 2) + Z_PARAM_LONG(pid) + Z_PARAM_LONG(pgid) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); if (setpgid(pid, pgid) < 0) { POSIX_G(last_error) = errno; @@ -640,9 +644,10 @@ PHP_FUNCTION(posix_setpgid) PHP_FUNCTION(posix_getpgid) { zend_long val; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &val) == FAILURE) { - RETURN_FALSE; - } + + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_LONG(val) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); if ((val = getpgid(val)) < 0) { POSIX_G(last_error) = errno; @@ -659,9 +664,10 @@ PHP_FUNCTION(posix_getpgid) PHP_FUNCTION(posix_getsid) { zend_long val; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &val) == FAILURE) { - RETURN_FALSE; - } + + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_LONG(val) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); if ((val = getsid(val)) < 0) { POSIX_G(last_error) = errno; @@ -788,9 +794,9 @@ PHP_FUNCTION(posix_ttyname) zend_long buflen; #endif - if (zend_parse_parameters(ZEND_NUM_ARGS(), "z", &z_fd) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_ZVAL_DEREF(z_fd) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); switch (Z_TYPE_P(z_fd)) { case IS_RESOURCE: @@ -833,9 +839,9 @@ PHP_FUNCTION(posix_isatty) zval *z_fd; int fd; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "z", &z_fd) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_ZVAL_DEREF(z_fd) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); switch (Z_TYPE_P(z_fd)) { case IS_RESOURCE: @@ -895,20 +901,20 @@ PHP_FUNCTION(posix_getcwd) #ifdef HAVE_MKFIFO PHP_FUNCTION(posix_mkfifo) { - char *path; - size_t path_len; + zend_string *path; zend_long mode; int result; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "pl", &path, &path_len, &mode) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(2, 2) + Z_PARAM_PATH_STR(path) + Z_PARAM_LONG(mode) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); - if (php_check_open_basedir_ex(path, 0)) { + if (php_check_open_basedir_ex(ZSTR_VAL(path), 0)) { RETURN_FALSE; } - result = mkfifo(path, mode); + result = mkfifo(ZSTR_VAL(path), mode); if (result < 0) { POSIX_G(last_error) = errno; RETURN_FALSE; @@ -924,21 +930,21 @@ PHP_FUNCTION(posix_mkfifo) #ifdef HAVE_MKNOD PHP_FUNCTION(posix_mknod) { - char *path; - size_t path_len; + zend_string *path; zend_long mode; zend_long major = 0, minor = 0; int result; - dev_t php_dev; + dev_t php_dev = 0; - php_dev = 0; + ZEND_PARSE_PARAMETERS_START(2, 4) + Z_PARAM_PATH_STR(path) + Z_PARAM_LONG(mode) + Z_PARAM_OPTIONAL + Z_PARAM_LONG(major) + Z_PARAM_LONG(minor) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); - if (zend_parse_parameters(ZEND_NUM_ARGS(), "pl|ll", &path, &path_len, - &mode, &major, &minor) == FAILURE) { - RETURN_FALSE; - } - - if (php_check_open_basedir_ex(path, 0)) { + if (php_check_open_basedir_ex(ZSTR_VAL(path), 0)) { RETURN_FALSE; } @@ -960,7 +966,7 @@ PHP_FUNCTION(posix_mknod) } } - result = mknod(path, mode, php_dev); + result = mknod(ZSTR_VAL(path), mode, php_dev); if (result < 0) { POSIX_G(last_error) = errno; RETURN_FALSE; @@ -1016,9 +1022,11 @@ PHP_FUNCTION(posix_access) size_t filename_len, ret; char *filename, *path; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "p|l", &filename, &filename_len, &mode) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 2) + Z_PARAM_PATH(filename, filename_len) + Z_PARAM_OPTIONAL + Z_PARAM_LONG(mode) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); path = expand_filepath(filename, NULL); if (!path) { @@ -1064,9 +1072,9 @@ PHP_FUNCTION(posix_getgrnam) char *buf; #endif - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s", &name, &name_len) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_STRING(name, name_len) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); #if defined(ZTS) && defined(HAVE_GETGRNAM_R) && defined(_SC_GETGR_R_SIZE_MAX) buflen = sysconf(_SC_GETGR_R_SIZE_MAX); @@ -1114,9 +1122,10 @@ PHP_FUNCTION(posix_getgrgid) #endif struct group *g; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &gid) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_LONG(gid) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); + #if defined(ZTS) && defined(HAVE_GETGRGID_R) && defined(_SC_GETGR_R_SIZE_MAX) grbuflen = sysconf(_SC_GETGR_R_SIZE_MAX); @@ -1183,9 +1192,9 @@ PHP_FUNCTION(posix_getpwnam) char *buf; #endif - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s", &name, &name_len) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_STRING(name, name_len) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); #if defined(ZTS) && defined(_SC_GETPW_R_SIZE_MAX) && defined(HAVE_GETPWNAM_R) buflen = sysconf(_SC_GETPW_R_SIZE_MAX); @@ -1233,9 +1242,10 @@ PHP_FUNCTION(posix_getpwuid) #endif struct passwd *pw; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &uid) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_LONG(uid) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); + #if defined(ZTS) && defined(_SC_GETPW_R_SIZE_MAX) && defined(HAVE_GETPWUID_R) pwbuflen = sysconf(_SC_GETPW_R_SIZE_MAX); if (pwbuflen < 1) { @@ -1395,9 +1405,11 @@ PHP_FUNCTION(posix_setrlimit) struct rlimit rl; zend_long res, cur, max; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "lll", &res, &cur, &max) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(3, 3) + Z_PARAM_LONG(res) + Z_PARAM_LONG(cur) + Z_PARAM_LONG(max) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); rl.rlim_cur = cur; rl.rlim_max = max; @@ -1430,9 +1442,9 @@ PHP_FUNCTION(posix_strerror) { zend_long error; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "l", &error) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(1, 1) + Z_PARAM_LONG(error) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); RETURN_STRING(strerror(error)); } @@ -1449,9 +1461,10 @@ PHP_FUNCTION(posix_initgroups) char *name; size_t name_len; - if (zend_parse_parameters(ZEND_NUM_ARGS(), "sl", &name, &name_len, &basegid) == FAILURE) { - RETURN_FALSE; - } + ZEND_PARSE_PARAMETERS_START(2, 2) + Z_PARAM_STRING(name, name_len) + Z_PARAM_LONG(basegid) + ZEND_PARSE_PARAMETERS_END_EX(RETURN_FALSE); if (name_len == 0) { RETURN_FALSE; |