SD总线信号未调用cb函数

时间:2018-09-07 06:36:48

标签: c++ linux ipc systemd dbus

我有一个问题。在c ++应用程序中,我使用的是sd-bus,信号不调用我的回调函数。

我迷上了 org.freedesktop.login1 ,界面是 org.freedesktop.DBus.Properties ,成员是 PropertiesChanged ,路径是< em> / org / freedesktop / login1 / seat / seat0

在我的connect方法中,我有这个:

sd_bus_add_match(m_bus, NULL, "interface='org.freedesktop.DBus.Properties',member='PropertiesChanged',path='/org/freedesktop/login1/seat/seat0',type='signal'", on_properties_changed, NULL)

更改属性的方法是这样的:

static int on_properties_changed(sd_bus_message *m, void *userdata, sd_bus_error *ret_error) {
    printf("got some signal");
}

所以,当我运行该程序时,我也在cmd中运行了以下命令:¸

gdbus monitor --system --dest org.freedesktop.login1 --object-path /org/freedesktop/login1/seat/seat0

但是,当我从userA切换到userB时,在cmd窗口中出现以下行:

/org/freedesktop/login1/seat/seat0: org.freedesktop.DBus.Properties.PropertiesChanged ('org.freedesktop.login1.Seat', {'ActiveSession': <('c7', objectpath '/org/freedesktop/login1/session/c7')>}, @as [])

也是我尝试的时候

busctl --system --match "interface='org.freedesktop.DBus.Properties',member='PropertiesChanged',path='/org/freedesktop/login1/seat/seat0',type='signal' monitor

然后我也会得到正确的答复

Type=signal  Endian=l  Flags=1  Version=1  Priority=0 Cookie=2281
  Sender=:1.0  Path=/org/freedesktop/login1/seat/seat0  Interface=org.freedesktop.DBus.Properties  Member=PropertiesChanged
  UniqueName=:1.0
  MESSAGE "sa{sv}as" {
          STRING "org.freedesktop.login1.Seat";
          ARRAY "{sv}" {
                  DICT_ENTRY "sv" {
                          STRING "ActiveSession";
                          VARIANT "(so)" {
                                  STRUCT "so" {
                                          STRING "c2";
                                          OBJECT_PATH "/org/freedesktop/login1/session/c2";
                                  };
                          };
                  };
          };
          ARRAY "s" {
          };
  };

但是在c ++中,没有调用回调函数。知道为什么不叫它吗?

我正在使用Ubuntu 16.04,我的系统版本是229。

1 个答案:

答案 0 :(得分:1)

我找到了解决此问题的方法。问题是我没有陷入任何事件循环。

所以我创建了新函数 run(),在这个函数中我这样说:

TCSANOW - the change shall occur immediately

现在我在连接信号后调用此函数,通常会调用sd_bus_add_match的回调函数