diff options
| author | Ilia Alshanetsky <iliaa@php.net> | 2003-01-03 18:33:28 +0000 | 
|---|---|---|
| committer | Ilia Alshanetsky <iliaa@php.net> | 2003-01-03 18:33:28 +0000 | 
| commit | f99fa7170eb39d4604424fdefd1d6556a99fe6bb (patch) | |
| tree | 7deef5f6c6afbedf9c684e90a364c5c2fd7a15dd | |
| parent | 71ab7dfccca65d28fd946cb6988b8e52d48461b8 (diff) | |
| download | php-git-f99fa7170eb39d4604424fdefd1d6556a99fe6bb.tar.gz | |
Fixed a bug that would cause flock() to never set the 3rd argument.
CS fixes & switched to new parameter parsing API.
| -rw-r--r-- | ext/standard/file.c | 42 | 
1 files changed, 21 insertions, 21 deletions
| diff --git a/ext/standard/file.c b/ext/standard/file.c index ca87537691..8903d2ca4d 100644 --- a/ext/standard/file.c +++ b/ext/standard/file.c @@ -212,38 +212,38 @@ static int flock_values[] = { LOCK_SH, LOCK_EX, LOCK_UN };  PHP_FUNCTION(flock)  { -    zval **arg1, **arg2, **arg3; -    int fd, act, ret, arg_count = ZEND_NUM_ARGS(); +	zval *arg1, *arg3; +	int fd, act, ret;  	php_stream *stream; +	long operation = 0; -    if (arg_count > 3 || zend_get_parameters_ex(arg_count, &arg1, &arg2, &arg3) == FAILURE) { -        WRONG_PARAM_COUNT; -    } +	if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "rl|z", &arg1, &operation, &arg3) == FAILURE) { +		return; +	} -	php_stream_from_zval(stream, arg1); +	php_stream_from_zval(stream, &arg1); -	if (php_stream_cast(stream, PHP_STREAM_AS_FD, (void*)&fd, 1) == FAILURE)	{ +	if (php_stream_cast(stream, PHP_STREAM_AS_FD, (void*)&fd, 1) == FAILURE) {  		RETURN_FALSE;  	} -	convert_to_long_ex(arg2); - -    act = Z_LVAL_PP(arg2) & 3; -    if (act < 1 || act > 3) { +	act = operation & 3; +	if (act < 1 || act > 3) {  		php_error_docref(NULL TSRMLS_CC, E_WARNING, "Illegal operation argument");  		RETURN_FALSE; -    } +	} -    /* flock_values contains all possible actions -       if (arg2 & 4) we won't block on the lock */ -    act = flock_values[act - 1] | (Z_LVAL_PP(arg2) & 4 ? LOCK_NB : 0); -    if ((ret=flock(fd, act)) == -1) { -        RETURN_FALSE; -    } -	if(ret == -1 && errno == EWOULDBLOCK && arg_count == 3) { -		ZVAL_LONG(*arg3, 1); +	/* flock_values contains all possible actions if (operation & 4) we won't block on the lock */ +	act = flock_values[act - 1] | (operation & 4 ? LOCK_NB : 0); +	if ((ret = flock(fd, act)) == -1) { +		if (errno == EWOULDBLOCK && operation) { +			convert_to_long(arg3); +			Z_LVAL_P(arg3) = 1; +			RETURN_TRUE; +		} +		RETURN_FALSE;  	} -    RETURN_TRUE; +	RETURN_TRUE;  }  /* }}} */ | 
