1

dbus C API の例http://www.matthew.ath.cx/misc/dbusがあります。また、改善された github にもあります https://github.com/wware/stuff/blob/master/dbus-example/dbus-example.c。呼び出しを行って応答を取得する query() 関数では、19 行目から 23 行目を追加して、以下に示すようにタイムアウトを処理する必要がありますか? 実行する場合、20 行目の保留中の行で ...unref を呼び出す必要がありますか? この例の流れを読んで、それが私たちのやるべきことだと思います。

// send message and get a handle for a reply
if (!dbus_connection_send_with_reply (conn, msg, &pending, -1)) { // -1 is default timeout
    fprintf(stderr, "Out Of Memory!\n"); 
    exit(1);
}
if (NULL == pending) { 
    fprintf(stderr, "Pending Call Null\n"); 
    exit(1); 
}
dbus_connection_flush(conn);

printf("Request Sent\n");

// free message
dbus_message_unref(msg);

// block until we recieve a reply
dbus_pending_call_block(pending);

/*do we need to handle the timeout case? -- line 20*/
if ( ! dbus_pending_call_get_completed(pending) ) {
    /*do we need to unref pending?  -- line 22 */
    dbus_pending_call_unref(pending); /* --line 23 */
    fprintf(stderr, "Reply timeout\n"); 
    return(1); 
}
4

1 に答える 1

0

いくつか読んで実験した後、答えは次のとおりです。

if ( ! dbus_pending_call_get_completed(pending) ) {
    /* always safe to call cancel */
    dbus_pending_call_cancel(pending);

    /*do we need to unref pending? yes. if not it would be a memory leak */
    dbus_pending_call_unref(pending);
    fprintf(stderr, "Reply failed to complete\n"); 
    return(1); 
}
/* timeout notes:
 *   it always reaches here, _completed() always returns true.
 *   if destination name does not exist, it consumes 0 time and returns
 *           a string indicating the possible error.
 *   if destination replies late, it consumes full timeout duration and
 *           returns a string about the possible error.
 * to abort before complete, use the _cancel() call. it is safe to call 
 * _cancel() even if it has been completed. 
 */
于 2015-10-08T04:19:32.190 に答える