Интеграция с D-Bus
D-Bus тесно интегрирован в язык и его использование в Vala как никогда просто.
Для того, чтобы экспортировать класс как сервис D-Bus нужно просто написать аннотацию с атрибутами D-Bus и зарегистрировать экземпляр этого класса с локальной сессией D-Bus.
[DBus(name = "org.example.DemoService")]
public class DemoService : Object {
/* Private поле, не экспортируется через D-Bus */
int counter;
/* Public поле, не экспортируется через D-Bus */
public int status;
/* Public свойство, экспортируется через D-Bus */
public int something { get; set; }
/* Public сигнал, экспортируется через D-Bus
* Может быть выброшен на стороне сервера и присоединен на стороне клиента.
*/
public signal void sig1();
/* Public метод, экспортируется через D-Bus */
public void some_method() {
counter++;
stdout.printf("Эврика! counter = %d\n", counter);
sig1(); // генерация сигнала
}
/* Public method, exported via D-Bus and showing the sender who is
is calling the method (not exported in the D-Bus interface) */
public void some_method_sender(string message, GLib.BusName sender) {
counter++;
stdout.printf("Эврика! counter = %d, '%s' message from sender %s\n",
counter, message, sender);
}
}Регистрируем сервис и начинаем главный цикл:
Компилировать нужно с пакетом dbus-glib-1:
Все названия в Vala, имеющие вид lower_case_with_underscores автоматически транслируются к виду CamelCase как принято в D-Bus. Экспортируемый D-Bus интерфейс указанного примера будет иметь свойство Something, сигнал Sig1 и метод SomeMethod. Вы можете открыть новое окно терминала и вызвать метод командой:
or
Вы можете так же использовать графический отладчик D-Bus типа D-Feet, чтобы смотреть интерфейс D-Bus и вызываемые методы.
Более продвинутые примеры: Vala/DBusClientSamples и Vala/DBusServerSample
Last updated
Was this helpful?