]> granicus.if.org Git - php/commitdiff
Use new param API in posix
authorSara Golemon <pollita@php.net>
Wed, 28 Dec 2016 19:48:36 +0000 (11:48 -0800)
committerSara Golemon <pollita@php.net>
Wed, 28 Dec 2016 19:48:36 +0000 (11:48 -0800)
ext/posix/posix.c

index 771e31632526e20243748d73c150d8977fff1781..2d1e300a473a0107e2dcd3302a8708900e97a821 100644 (file)
@@ -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;