You got quite a few typos there. For example:
- fifeth_arg_force_ref (fifth)
- PHP_SEM_NOT_AVAILEBLE (AVAILABLE)
- allready

Following constants are against coding standards:
- "ENOENT",
- EEXIST

zval_dtor(error_code); should be zval_ptr_dtor(&error_code) to make sure you protect reference counting.

In general, I suggest to go over the patch again and make sure you improve things and then repost it to this list. Unfortunately I don't have time to fix it myself.

Andi


At 09:52 AM 4/6/2005 +0300, Pauli wrote:
Is this patch possible to get in php 5.x? What should I improve so my patch would get reviewed?

I would need it in php 5.0 my self. It would come to comercial webserver so there is required _stable_ build which won't self build and patched version. Specialy because this was first time I ever looked php source code. (Happily using it about 5 years now)

Should I make some changes to documentation also? I didn't got time to
check it out yet how to change documentation.

I checked that 5.0 and 5.1 branches got same source for this file so
this patch could be applied for both of them. There was some minor
changes from 4.3 branch.

I tested this with 5.0 cvs branch (checkout today). It worked well after
I got sem_acquire parameter parsing converted to new functions. I got little confused with that I must read everything to zval and then convert it to what I want.


This patch is adds IPC_CREAT, IPC_EXCL and IPC_NOWAIT functionality to
sem_get and sem_acquire. The code changes add some constants and handles
those constants as parameters.  There is possible issue that sem_get
could get unwanted parameters because values aren't checked before they
are passed to 'real' sem_get but that was functionality of old
implementation so I didn't want to change it.

Here is  also changed sem_acquire to use new parameter parsing function.

I included 2 php test cases that I demo straits functionality of new
implemantion. test.php is not mean to output anything special.
test_nowait.php. Shows what happens if semaphore is tried to access same
time by 2 scripts. Execute test_nowait in 2 shells same time. The first
one to terminate should tell you that 2nd acquire was busy. 2nd should
tell that 2nd acquire was also successful.

http://cmax.gg/~coren/bug26610.patch

http://cmax.gg/~coren/test.phps
http://cmax.gg/~coren/test_nowait.phps

That's it. Thanks for comments and help how to improve this patch. Also
big thanks for reading to end. ;)

--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

-- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php



Reply via email to