[zeromq-dev] czmq v3.0.0: zsys_handler_set - different semantics from v2 API

Pieter Hintjens ph at imatix.com
Wed May 20 14:08:21 CEST 2015


We always make PRs against master.

On Wed, May 20, 2015 at 10:14 AM, Michael Haberler <mail17 at mah.priv.at> wrote:
>
>> Am 20.05.2015 um 08:53 schrieb Pieter Hintjens <ph at imatix.com>:
>>
>> Looks good to me. Thanks!
>
> hm, it seems I'm unable to create a PR against a commit/tag: https://github.com/zeromq/czmq/compare/9c24aea3defe84cd72d7e6ac1845b6215f3d7aad...mhaberler:v3.0.0-work
>
> not sure how to proceed?
>
> - Michael
>
>>
>> On Wed, May 20, 2015 at 8:00 AM, Michael Haberler <mail17 at mah.priv.at> wrote:
>>> in czmq v2.x, if you did a zsys_handler_set(NULL) at the beginning of the program, czmq would refrain from _any_ signal handling which is what I need (I do that synchronously with signalfd for those signals which can be trapped by signalfd)
>>>
>>> v3.0.0 outsmarts me by insisting on calling zsys_catch_interrupts() from zsys_init() if ZSYS_SIGHANDLER is not set, and that interferes with signalfd handling
>>>
>>> I guess the proper way would be to call  zsys_catch_interrupts() ONLY if s_first_time is true
>>>
>>> if agreed, I'll prepare a PR
>>>
>>> - Michael
>>>
>>> @@ -160,12 +160,12 @@ zsys_init (void)
>>>         else
>>>         if (streq (getenv ("ZSYS_LOGSYSTEM"), "false"))
>>>             s_logsystem = false;
>>>     }
>>>     //  Catch SIGINT and SIGTERM unless ZSYS_SIGHANDLER=false
>>> -    if (  getenv ("ZSYS_SIGHANDLER") == NULL
>>> -       || strneq (getenv ("ZSYS_SIGHANDLER"), "false"))
>>> +    if ((  getenv ("ZSYS_SIGHANDLER") == NULL
>>> +          || strneq (getenv ("ZSYS_SIGHANDLER"), "false")) && s_first_time)
>>>         zsys_catch_interrupts ();
>>>
>>>     ZMUTEX_INIT (s_mutex);
>>>     s_sockref_list = zlist_new ();
>>>     if (!s_sockref_list) {
>>> _______________________________________________
>>> zeromq-dev mailing list
>>> zeromq-dev at lists.zeromq.org
>>> http://lists.zeromq.org/mailman/listinfo/zeromq-dev
>> _______________________________________________
>> zeromq-dev mailing list
>> zeromq-dev at lists.zeromq.org
>> http://lists.zeromq.org/mailman/listinfo/zeromq-dev
>
> _______________________________________________
> zeromq-dev mailing list
> zeromq-dev at lists.zeromq.org
> http://lists.zeromq.org/mailman/listinfo/zeromq-dev



More information about the zeromq-dev mailing list