Mercurial > emacs
annotate lisp/net/dbus.el @ 111991:968255ee954a
Support for menu separators in the GTK tool-bar.
* src/gtkutil.c (XG_BIN_CHILD): New macro.
(xg_get_menu_item_label, xg_update_menubar)
(xg_update_menu_item, xg_tool_bar_menu_proxy)
(xg_show_toolbar_item, update_frame_tool_bar): Use it.
(separator_names, xg_separator_p): Move to keyboard.c.
(create_menus, xg_update_submenu, update_frame_tool_bar): Use
menu_separator_name_p.
* src/keyboard.c (parse_tool_bar_item): Allow menu separators in
tool-bar maps.
(menu_separator_name_p): New function, from gtkutil.c.
(separator_names): Move from gtkutil.c.
* src/keyboard.h (menu_separator_name_p): Add prototype.
* src/nsmenu.m (name_is_separator): Function deleted.
(addItemWithWidgetValue): Use menu_separator_name_p.
* src/w32menu.c (name_is_separator): Function deleted.
(add_menu_item): Use menu_separator_name_p.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Fri, 17 Dec 2010 12:04:06 +0800 |
parents | de02b794c330 |
children | 318b7249ccd0 |
rev | line source |
---|---|
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
1 ;;; dbus.el --- Elisp bindings for D-Bus. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
2 |
106815 | 3 ;; Copyright (C) 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
4 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
5 ;; Author: Michael Albinus <michael.albinus@gmx.de> |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
6 ;; Keywords: comm, hardware |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
7 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
8 ;; This file is part of GNU Emacs. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
9 |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91728
diff
changeset
|
10 ;; GNU Emacs is free software: you can redistribute it and/or modify |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
11 ;; it under the terms of the GNU General Public License as published by |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91728
diff
changeset
|
12 ;; the Free Software Foundation, either version 3 of the License, or |
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91728
diff
changeset
|
13 ;; (at your option) any later version. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
14 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
15 ;; GNU Emacs is distributed in the hope that it will be useful, |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
18 ;; GNU General Public License for more details. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
19 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
20 ;; You should have received a copy of the GNU General Public License |
94677
91e5880a36c1
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91728
diff
changeset
|
21 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
22 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
23 ;;; Commentary: |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
24 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
25 ;; This package provides language bindings for the D-Bus API. D-Bus |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
26 ;; is a message bus system, a simple way for applications to talk to |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
27 ;; one another. See <http://dbus.freedesktop.org/> for details. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
28 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
29 ;; Low-level language bindings are implemented in src/dbusbind.c. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
30 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
31 ;;; Code: |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
32 |
91484
7ddf7059d131
* dbus.el (top): Check (featurep 'dbusbind).
Michael Albinus <michael.albinus@gmx.de>
parents:
87885
diff
changeset
|
33 ;; D-Bus support in the Emacs core can be disabled with configuration |
91728
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
34 ;; option "--without-dbus". Declare used subroutines and variables. |
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
35 (declare-function dbus-call-method "dbusbind.c") |
97261
d5e87cca37af
* net/dbus.el (dbus-call-method-asynchronously): Declare
Michael Albinus <michael.albinus@gmx.de>
parents:
97260
diff
changeset
|
36 (declare-function dbus-call-method-asynchronously "dbusbind.c") |
104337
709480950021
* net/dbus.el (dbus-init-bus): Declare. Apply it for the :system
Michael Albinus <michael.albinus@gmx.de>
parents:
104081
diff
changeset
|
37 (declare-function dbus-init-bus "dbusbind.c") |
97260
409001287195
* net/dbus.el (dbus-method-return-internal)
Michael Albinus <michael.albinus@gmx.de>
parents:
97213
diff
changeset
|
38 (declare-function dbus-method-return-internal "dbusbind.c") |
409001287195
* net/dbus.el (dbus-method-return-internal)
Michael Albinus <michael.albinus@gmx.de>
parents:
97213
diff
changeset
|
39 (declare-function dbus-method-error-internal "dbusbind.c") |
91728
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
40 (declare-function dbus-register-signal "dbusbind.c") |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
41 (declare-function dbus-register-method "dbusbind.c") |
109132
0f3ed79830e9
* net/dbus.el (dbus-send-signal): Declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
109127
diff
changeset
|
42 (declare-function dbus-send-signal "dbusbind.c") |
91728
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
43 (defvar dbus-debug) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
44 (defvar dbus-registered-objects-table) |
91728
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
45 |
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
46 ;; Pacify byte compiler. |
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
47 (eval-when-compile |
58bf306db72e
* net/dbus.el: Remove `no-byte-compile' cookie.
Michael Albinus <michael.albinus@gmx.de>
parents:
91589
diff
changeset
|
48 (require 'cl)) |
91484
7ddf7059d131
* dbus.el (top): Check (featurep 'dbusbind).
Michael Albinus <michael.albinus@gmx.de>
parents:
87885
diff
changeset
|
49 |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
50 (require 'xml) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
51 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
52 (defconst dbus-service-dbus "org.freedesktop.DBus" |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
53 "The bus name used to talk to the bus itself.") |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
54 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
55 (defconst dbus-path-dbus "/org/freedesktop/DBus" |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
56 "The object path used to talk to the bus itself.") |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
57 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
58 (defconst dbus-interface-dbus "org.freedesktop.DBus" |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
59 "The interface exported by the object with `dbus-service-dbus' and `dbus-path-dbus'.") |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
60 |
91588
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
61 (defconst dbus-interface-peer (concat dbus-interface-dbus ".Peer") |
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
62 "The interface for peer objects.") |
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
63 |
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
64 (defconst dbus-interface-introspectable |
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
65 (concat dbus-interface-dbus ".Introspectable") |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
66 "The interface supported by introspectable objects.") |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
67 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
68 (defconst dbus-interface-properties (concat dbus-interface-dbus ".Properties") |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
69 "The interface for property objects.") |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
70 |
98668
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
71 (defconst dbus-service-emacs "org.gnu.Emacs" |
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
72 "The well known service name of Emacs.") |
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
73 |
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
74 (defconst dbus-path-emacs "/org/gnu/Emacs" |
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
75 "The object path head used by Emacs.") |
a7acd2697027
* net/dbus.el (dbus-service-emacs, dbus-path-emacs): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
97692
diff
changeset
|
76 |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
77 (defconst dbus-message-type-invalid 0 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
78 "This value is never a valid message type.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
79 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
80 (defconst dbus-message-type-method-call 1 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
81 "Message type of a method call message.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
82 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
83 (defconst dbus-message-type-method-return 2 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
84 "Message type of a method return message.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
85 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
86 (defconst dbus-message-type-error 3 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
87 "Message type of an error reply message.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
88 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
89 (defconst dbus-message-type-signal 4 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
90 "Message type of a signal message.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
91 |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
92 (defmacro dbus-ignore-errors (&rest body) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
93 "Execute BODY; signal D-Bus error when `dbus-debug' is non-nil. |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
94 Otherwise, return result of last form in BODY, or all other errors." |
110034
c87f89486bb7
Use `declare' in defmacros.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109962
diff
changeset
|
95 (declare (indent 0) (debug t)) |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
96 `(condition-case err |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
97 (progn ,@body) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
98 (dbus-error (when dbus-debug (signal (car err) (cdr err)))))) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
99 (font-lock-add-keywords 'emacs-lisp-mode '("\\<dbus-ignore-errors\\>")) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
100 |
101525
5951f5343bb5
* net/dbus.el (dbus-event-error-hooks): New variable.
Michael Albinus <michael.albinus@gmx.de>
parents:
100855
diff
changeset
|
101 (defvar dbus-event-error-hooks nil |
5951f5343bb5
* net/dbus.el (dbus-event-error-hooks): New variable.
Michael Albinus <michael.albinus@gmx.de>
parents:
100855
diff
changeset
|
102 "Functions to be called when a D-Bus error happens in the event handler. |
101619
df3f6041e002
* net/dbus.el (dbus-event-error-hooks): Fix docstring. Describe
Michael Albinus <michael.albinus@gmx.de>
parents:
101525
diff
changeset
|
103 Every function must accept two arguments, the event and the error variable |
101525
5951f5343bb5
* net/dbus.el (dbus-event-error-hooks): New variable.
Michael Albinus <michael.albinus@gmx.de>
parents:
100855
diff
changeset
|
104 catched in `condition-case' by `dbus-error'.") |
5951f5343bb5
* net/dbus.el (dbus-event-error-hooks): New variable.
Michael Albinus <michael.albinus@gmx.de>
parents:
100855
diff
changeset
|
105 |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
106 |
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
107 ;;; Hash table of registered functions. |
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
108 |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
109 (defvar dbus-return-values-table (make-hash-table :test 'equal) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
110 "Hash table for temporary storing arguments of reply messages. |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
111 A key in this hash table is a list (BUS SERIAL). BUS is either a |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
112 Lisp symbol, `:system' or `:session', or a string denoting the |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
113 bus address. SERIAL is the serial number of the reply message. |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
114 See `dbus-call-method-non-blocking-handler' and |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
115 `dbus-call-method-non-blocking'.") |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
116 |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
117 (defun dbus-list-hash-table () |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
118 "Returns all registered member registrations to D-Bus. |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
119 The return value is a list, with elements of kind (KEY . VALUE). |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
120 See `dbus-registered-objects-table' for a description of the |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
121 hash table." |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
122 (let (result) |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
123 (maphash |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
124 '(lambda (key value) (add-to-list 'result (cons key value) 'append)) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
125 dbus-registered-objects-table) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
126 result)) |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
127 |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
128 (defun dbus-unregister-object (object) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
129 "Unregister OBJECT from D-Bus. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
130 OBJECT must be the result of a preceding `dbus-register-method', |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
131 `dbus-register-property' or `dbus-register-signal' call. It |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
132 returns `t' if OBJECT has been unregistered, `nil' otherwise. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
133 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
134 When OBJECT identifies the last method or property, which is |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
135 registered for the respective service, Emacs releases its |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
136 association to the service from D-Bus." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
137 ;; Check parameter. |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
138 (unless (and (consp object) (not (null (car object))) (consp (cdr object))) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
139 (signal 'wrong-type-argument (list 'D-Bus object))) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
140 |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
141 ;; Find the corresponding entry in the hash table. |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
142 (let* ((key (car object)) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
143 (value (cdr object)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
144 (entry (gethash key dbus-registered-objects-table)) |
105926
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
145 ret) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
146 ;; entry has the structure ((UNAME SERVICE PATH MEMBER) ...). |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
147 ;; value has the structure ((SERVICE PATH [HANDLER]) ...). |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
148 ;; MEMBER is either a string (the handler), or a cons cell (a |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
149 ;; property value). UNAME and property values are not taken into |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
150 ;; account for comparision. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
151 |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
152 ;; Loop over the registered functions. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
153 (dolist (elt entry) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
154 (when (equal |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
155 (car value) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
156 (butlast (cdr elt) (- (length (cdr elt)) (length (car value))))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
157 ;; Compute new hash value. If it is empty, remove it from the |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
158 ;; hash table. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
159 (unless (puthash key (delete elt entry) dbus-registered-objects-table) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
160 (remhash key dbus-registered-objects-table)) |
105926
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
161 (setq ret t))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
162 ;; Check, whether there is still a registered function or property |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
163 ;; for the given service. If not, unregister the service from the |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
164 ;; bus. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
165 (dolist (elt entry) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
166 (let ((service (cadr elt)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
167 (bus (car key)) |
105926
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
168 found) |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
169 (maphash |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
170 (lambda (k v) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
171 (dolist (e v) |
105926
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
172 (ignore-errors |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
173 (when (and (equal bus (car k)) (string-equal service (cadr e))) |
105928
d91d3722b71f
*** empty log message ***
Michael Albinus <michael.albinus@gmx.de>
parents:
105926
diff
changeset
|
174 (setq found t))))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
175 dbus-registered-objects-table) |
105926
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
176 (unless found |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
177 (dbus-call-method |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
178 bus dbus-service-dbus dbus-path-dbus dbus-interface-dbus |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
179 "ReleaseName" service)))) |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
180 ;; Return. |
2b4cc3e45a7b
* net/dbus.el (dbus-unregister-object): Release service, if no
Michael Albinus <michael.albinus@gmx.de>
parents:
104602
diff
changeset
|
181 ret)) |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
182 |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
183 (defun dbus-unregister-service (bus service) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
184 "Unregister all objects related to SERVICE from D-Bus BUS. |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
185 BUS is either a Lisp symbol, `:system' or `:session', or a string |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
186 denoting the bus address. SERVICE must be a known service name." |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
187 (maphash |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
188 (lambda (key value) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
189 (dolist (elt value) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
190 (ignore-errors |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
191 (when (and (equal bus (car key)) (string-equal service (cadr elt))) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
192 (unless |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
193 (puthash key (delete elt value) dbus-registered-objects-table) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
194 (remhash key dbus-registered-objects-table)))))) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
195 dbus-registered-objects-table) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
196 (dbus-call-method |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
197 bus dbus-service-dbus dbus-path-dbus dbus-interface-dbus |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
198 "ReleaseName" service)) |
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
199 |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
200 (defun dbus-call-method-non-blocking-handler (&rest args) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
201 "Handler for reply messages of asynchronous D-Bus message calls. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
202 It calls the function stored in `dbus-registered-objects-table'. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
203 The result will be made available in `dbus-return-values-table'." |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
204 (puthash (list (dbus-event-bus-name last-input-event) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
205 (dbus-event-serial-number last-input-event)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
206 (if (= (length args) 1) (car args) args) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
207 dbus-return-values-table)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
208 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
209 (defun dbus-call-method-non-blocking |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
210 (bus service path interface method &rest args) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
211 "Call METHOD on the D-Bus BUS, but don't block the event queue. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
212 This is necessary for communicating to registered D-Bus methods, |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
213 which are running in the same Emacs process. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
214 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
215 The arguments are the same as in `dbus-call-method'. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
216 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
217 usage: (dbus-call-method-non-blocking |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
218 BUS SERVICE PATH INTERFACE METHOD |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
219 &optional :timeout TIMEOUT &rest ARGS)" |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
220 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
221 (let ((key |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
222 (apply |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
223 'dbus-call-method-asynchronously |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
224 bus service path interface method |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
225 'dbus-call-method-non-blocking-handler args))) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
226 ;; Wait until `dbus-call-method-non-blocking-handler' has put the |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
227 ;; result into `dbus-return-values-table'. |
104081
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
228 (while (eq (gethash key dbus-return-values-table :ignore) :ignore) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
229 (read-event nil nil 0.1)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
230 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
231 ;; Cleanup `dbus-return-values-table'. Return the result. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
232 (prog1 |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
233 (gethash key dbus-return-values-table nil) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
234 (remhash key dbus-return-values-table)))) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
235 |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
236 (defun dbus-name-owner-changed-handler (&rest args) |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
237 "Reapplies all member registrations to D-Bus. |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
238 This handler is applied when a \"NameOwnerChanged\" signal has |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
239 arrived. SERVICE is the object name for which the name owner has |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
240 been changed. OLD-OWNER is the previous owner of SERVICE, or the |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
241 empty string if SERVICE was not owned yet. NEW-OWNER is the new |
111333
de02b794c330
Don't be so lax with spelling.
Glenn Morris <rgm@gnu.org>
parents:
110034
diff
changeset
|
242 owner of SERVICE, or the empty string if SERVICE loses any name owner. |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
243 |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
244 usage: (dbus-name-owner-changed-handler service old-owner new-owner)" |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
245 (save-match-data |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
246 ;; Check the arguments. We should silently ignore it when they |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
247 ;; are wrong. |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
248 (if (and (= (length args) 3) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
249 (stringp (car args)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
250 (stringp (cadr args)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
251 (stringp (caddr args))) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
252 (let ((service (car args)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
253 (old-owner (cadr args)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
254 (new-owner (caddr args))) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
255 ;; Check whether SERVICE is a known name. |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
256 (when (not (string-match "^:" service)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
257 (maphash |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
258 '(lambda (key value) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
259 (dolist (elt value) |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
260 ;; key has the structure (BUS INTERFACE MEMBER). |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
261 ;; elt has the structure (UNAME SERVICE PATH HANDLER). |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
262 (when (string-equal old-owner (car elt)) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
263 ;; Remove old key, and add new entry with changed name. |
87537
84ece2f8e012
* net/dbus.el (dbus-name-owner-changed-handler): Use
Magnus Henoch <mange@freemail.hu>
parents:
87492
diff
changeset
|
264 (dbus-unregister-object (list key (cdr elt))) |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
265 ;; Maybe we could arrange the lists a little bit better |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
266 ;; that we don't need to extract every single element? |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
267 (dbus-register-signal |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
268 ;; BUS SERVICE PATH |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
269 (nth 0 key) (nth 1 elt) (nth 2 elt) |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
270 ;; INTERFACE MEMBER HANDLER |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
271 (nth 1 key) (nth 2 key) (nth 3 elt))))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
272 (copy-hash-table dbus-registered-objects-table)))) |
87492
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
273 ;; The error is reported only in debug mode. |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
274 (when dbus-debug |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
275 (signal |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
276 'dbus-error |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
277 (cons |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
278 (format "Wrong arguments of %s.NameOwnerChanged" dbus-interface-dbus) |
bb538e56f976
* net/dbus.el (dbus-name-owner-changed-handler): Make the function
Michael Albinus <michael.albinus@gmx.de>
parents:
87308
diff
changeset
|
279 args)))))) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
280 |
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
281 ;; Register the handler. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
282 (when nil ;ignore-errors |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
283 (dbus-register-signal |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
284 :system dbus-service-dbus dbus-path-dbus dbus-interface-dbus |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
285 "NameOwnerChanged" 'dbus-name-owner-changed-handler) |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
286 (dbus-register-signal |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
287 :session dbus-service-dbus dbus-path-dbus dbus-interface-dbus |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
288 "NameOwnerChanged" 'dbus-name-owner-changed-handler)) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
289 |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
290 |
99951
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
291 ;;; D-Bus type conversion. |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
292 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
293 (defun dbus-string-to-byte-array (string) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
294 "Transforms STRING to list (:array :byte c1 :byte c2 ...). |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
295 STRING shall be UTF8 coded." |
100855
4502d2277f2c
* net/dbus.el (dbus-string-to-byte-array): Handle empty array.
Michael Albinus <michael.albinus@gmx.de>
parents:
99968
diff
changeset
|
296 (if (zerop (length string)) |
4502d2277f2c
* net/dbus.el (dbus-string-to-byte-array): Handle empty array.
Michael Albinus <michael.albinus@gmx.de>
parents:
99968
diff
changeset
|
297 '(:array :signature "y") |
4502d2277f2c
* net/dbus.el (dbus-string-to-byte-array): Handle empty array.
Michael Albinus <michael.albinus@gmx.de>
parents:
99968
diff
changeset
|
298 (let (result) |
4502d2277f2c
* net/dbus.el (dbus-string-to-byte-array): Handle empty array.
Michael Albinus <michael.albinus@gmx.de>
parents:
99968
diff
changeset
|
299 (dolist (elt (string-to-list string) (append '(:array) result)) |
4502d2277f2c
* net/dbus.el (dbus-string-to-byte-array): Handle empty array.
Michael Albinus <michael.albinus@gmx.de>
parents:
99968
diff
changeset
|
300 (setq result (append result (list :byte elt))))))) |
99951
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
301 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
302 (defun dbus-byte-array-to-string (byte-array) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
303 "Transforms BYTE-ARRAY into UTF8 coded string. |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
304 BYTE-ARRAY must be a list of structure (c1 c2 ...)." |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
305 (apply 'string byte-array)) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
306 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
307 (defun dbus-escape-as-identifier (string) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
308 "Escape an arbitrary STRING so it follows the rules for a C identifier. |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
309 The escaped string can be used as object path component, interface element |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
310 component, bus name component or member name in D-Bus. |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
311 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
312 The escaping consists of replacing all non-alphanumerics, and the |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
313 first character if it's a digit, with an underscore and two |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
314 lower-case hex digits: |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
315 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
316 \"0123abc_xyz\\x01\\xff\" -> \"_30123abc_5fxyz_01_ff\" |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
317 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
318 i.e. similar to URI encoding, but with \"_\" taking the role of \"%\", |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
319 and a smaller allowed set. As a special case, \"\" is escaped to |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
320 \"_\". |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
321 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
322 Returns the escaped string. Algorithm taken from |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
323 telepathy-glib's `tp-escape-as-identifier'." |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
324 (if (zerop (length string)) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
325 "_" |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
326 (replace-regexp-in-string |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
327 "^[0-9]\\|[^A-Za-z0-9]" |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
328 (lambda (x) (format "_%2x" (aref x 0))) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
329 string))) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
330 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
331 (defun dbus-unescape-from-identifier (string) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
332 "Retrieve the original string from the encoded STRING. |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
333 STRING must have been coded with `dbus-escape-as-identifier'" |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
334 (if (string-equal string "_") |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
335 "" |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
336 (replace-regexp-in-string |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
337 "_.." |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
338 (lambda (x) (format "%c" (string-to-number (substring x 1) 16))) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
339 string))) |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
340 |
b265d0564f99
* net/dbus.el (dbus-string-to-byte-array)
Michael Albinus <michael.albinus@gmx.de>
parents:
98668
diff
changeset
|
341 |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
342 ;;; D-Bus events. |
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
343 |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
344 (defun dbus-check-event (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
345 "Checks whether EVENT is a well formed D-Bus event. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
346 EVENT is a list which starts with symbol `dbus-event': |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
347 |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
348 (dbus-event BUS TYPE SERIAL SERVICE PATH INTERFACE MEMBER HANDLER &rest ARGS) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
349 |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
350 BUS identifies the D-Bus the message is coming from. It is |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
351 either a Lisp symbol, `:system' or `:session', or a string |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
352 denoting the bus address. TYPE is the D-Bus message type which |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
353 has caused the event, SERIAL is the serial number of the received |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
354 D-Bus message. SERVICE and PATH are the unique name and the |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
355 object path of the D-Bus object emitting the message. INTERFACE |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
356 and MEMBER denote the message which has been sent. HANDLER is |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
357 the function which has been registered for this message. ARGS |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
358 are the arguments passed to HANDLER, when it is called during |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
359 event handling in `dbus-handle-event'. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
360 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
361 This function raises a `dbus-error' signal in case the event is |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
362 not well formed." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
363 (when dbus-debug (message "DBus-Event %s" event)) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
364 (unless (and (listp event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
365 (eq (car event) 'dbus-event) |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
366 ;; Bus symbol. |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
367 (or (symbolp (nth 1 event)) |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
368 (stringp (nth 1 event))) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
369 ;; Type. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
370 (and (natnump (nth 2 event)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
371 (< dbus-message-type-invalid (nth 2 event))) |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
372 ;; Serial. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
373 (natnump (nth 3 event)) |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
374 ;; Service. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
375 (or (= dbus-message-type-method-return (nth 2 event)) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
376 (= dbus-message-type-error (nth 2 event)) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
377 (stringp (nth 4 event))) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
378 ;; Object path. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
379 (or (= dbus-message-type-method-return (nth 2 event)) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
380 (= dbus-message-type-error (nth 2 event)) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
381 (stringp (nth 5 event))) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
382 ;; Interface. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
383 (or (= dbus-message-type-method-return (nth 2 event)) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
384 (= dbus-message-type-error (nth 2 event)) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
385 (stringp (nth 6 event))) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
386 ;; Member. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
387 (or (= dbus-message-type-method-return (nth 2 event)) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
388 (= dbus-message-type-error (nth 2 event)) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
389 (stringp (nth 7 event))) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
390 ;; Handler. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
391 (functionp (nth 8 event))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
392 (signal 'dbus-error (list "Not a valid D-Bus event" event)))) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
393 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
394 ;;;###autoload |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
395 (defun dbus-handle-event (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
396 "Handle events from the D-Bus. |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
397 EVENT is a D-Bus event, see `dbus-check-event'. HANDLER, being |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
398 part of the event, is called with arguments ARGS. |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
399 If the HANDLER returns a `dbus-error', it is propagated as return message." |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
400 (interactive "e") |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
401 (condition-case err |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
402 (let (result) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
403 ;; We ignore not well-formed events. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
404 (dbus-check-event event) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
405 ;; Error messages must be propagated. |
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
406 (when (= dbus-message-type-error (nth 2 event)) |
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
407 (signal 'dbus-error (nthcdr 9 event))) |
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
408 ;; Apply the handler. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
409 (setq result (apply (nth 8 event) (nthcdr 9 event))) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
410 ;; Return a message when it is a message call. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
411 (when (= dbus-message-type-method-call (nth 2 event)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
412 (dbus-ignore-errors |
104081
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
413 (if (eq result :ignore) |
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
414 (dbus-method-return-internal |
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
415 (nth 1 event) (nth 3 event) (nth 4 event)) |
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
416 (apply 'dbus-method-return-internal |
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
417 (nth 1 event) (nth 3 event) (nth 4 event) |
4c431a52ce37
* net/dbus.el (dbus-call-method-non-blocking): Handle the case the
Michael Albinus <michael.albinus@gmx.de>
parents:
101619
diff
changeset
|
418 (if (consp result) result (list result))))))) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
419 ;; Error handling. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
420 (dbus-error |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
421 ;; Return an error message when it is a message call. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
422 (when (= dbus-message-type-method-call (nth 2 event)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
423 (dbus-ignore-errors |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
424 (dbus-method-error-internal |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
425 (nth 1 event) (nth 3 event) (nth 4 event) (cadr err)))) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
426 ;; Propagate D-Bus error messages. |
101619
df3f6041e002
* net/dbus.el (dbus-event-error-hooks): Fix docstring. Describe
Michael Albinus <michael.albinus@gmx.de>
parents:
101525
diff
changeset
|
427 (run-hook-with-args 'dbus-event-error-hooks event err) |
97213
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
428 (when (or dbus-debug (= dbus-message-type-error (nth 2 event))) |
f7035abd999b
* net/dbus.el (dbus-check-event, dbus-handle-event): Handle D-Bus
Michael Albinus <michael.albinus@gmx.de>
parents:
97167
diff
changeset
|
429 (signal (car err) (cdr err)))))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
430 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
431 (defun dbus-event-bus-name (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
432 "Return the bus name the event is coming from. |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
433 The result is either a Lisp symbol, `:system' or `:session', or a |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
434 string denoting the bus address. EVENT is a D-Bus event, see |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
435 `dbus-check-event'. This function raises a `dbus-error' signal |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
436 in case the event is not well formed." |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
437 (dbus-check-event event) |
87159
bcf59f3d73d7
* net/dbus.el (dbus-hash-table=): Fix for new hash table key
Michael Albinus <michael.albinus@gmx.de>
parents:
87093
diff
changeset
|
438 (nth 1 event)) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
439 |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
440 (defun dbus-event-message-type (event) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
441 "Return the message type of the corresponding D-Bus message. |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
442 The result is a number. EVENT is a D-Bus event, see |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
443 `dbus-check-event'. This function raises a `dbus-error' signal |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
444 in case the event is not well formed." |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
445 (dbus-check-event event) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
446 (nth 2 event)) |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
447 |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
448 (defun dbus-event-serial-number (event) |
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
449 "Return the serial number of the corresponding D-Bus message. |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
450 The result is a number. The serial number is needed for |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
451 generating a reply message. EVENT is a D-Bus event, see |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
452 `dbus-check-event'. This function raises a `dbus-error' signal |
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
453 in case the event is not well formed." |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
454 (dbus-check-event event) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
455 (nth 3 event)) |
87586
9554989ee375
* net/dbus.el (dbus-list-hash-table)
Michael Albinus <michael.albinus@gmx.de>
parents:
87537
diff
changeset
|
456 |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
457 (defun dbus-event-service-name (event) |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
458 "Return the name of the D-Bus object the event is coming from. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
459 The result is a string. EVENT is a D-Bus event, see `dbus-check-event'. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
460 This function raises a `dbus-error' signal in case the event is |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
461 not well formed." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
462 (dbus-check-event event) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
463 (nth 4 event)) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
464 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
465 (defun dbus-event-path-name (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
466 "Return the object path of the D-Bus object the event is coming from. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
467 The result is a string. EVENT is a D-Bus event, see `dbus-check-event'. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
468 This function raises a `dbus-error' signal in case the event is |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
469 not well formed." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
470 (dbus-check-event event) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
471 (nth 5 event)) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
472 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
473 (defun dbus-event-interface-name (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
474 "Return the interface name of the D-Bus object the event is coming from. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
475 The result is a string. EVENT is a D-Bus event, see `dbus-check-event'. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
476 This function raises a `dbus-error' signal in case the event is |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
477 not well formed." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
478 (dbus-check-event event) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
479 (nth 6 event)) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
480 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
481 (defun dbus-event-member-name (event) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
482 "Return the member name the event is coming from. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
483 It is either a signal name or a method name. The result is is a |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
484 string. EVENT is a D-Bus event, see `dbus-check-event'. This |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
485 function raises a `dbus-error' signal in case the event is not |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
486 well formed." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
487 (dbus-check-event event) |
97167
125ed717ddbb
* net/dbus.el (top): Don't register for "NameOwnerChanged".
Michael Albinus <michael.albinus@gmx.de>
parents:
96801
diff
changeset
|
488 (nth 7 event)) |
87050
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
489 |
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
490 |
7d80e0f3d8f8
* net/dbus.el (dbus-hash-table=): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
86941
diff
changeset
|
491 ;;; D-Bus registered names. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
492 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
493 (defun dbus-list-activatable-names () |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
494 "Return the D-Bus service names which can be activated as list. |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
495 The result is a list of strings, which is `nil' when there are no |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
496 activatable service names at all." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
497 (dbus-ignore-errors |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
498 (dbus-call-method |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
499 :system dbus-service-dbus |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
500 dbus-path-dbus dbus-interface-dbus "ListActivatableNames"))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
501 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
502 (defun dbus-list-names (bus) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
503 "Return the service names registered at D-Bus BUS. |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
504 The result is a list of strings, which is `nil' when there are no |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
505 registered service names at all. Well known names are strings |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
506 like \"org.freedesktop.DBus\". Names starting with \":\" are |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
507 unique names for services." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
508 (dbus-ignore-errors |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
509 (dbus-call-method |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
510 bus dbus-service-dbus dbus-path-dbus dbus-interface-dbus "ListNames"))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
511 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
512 (defun dbus-list-known-names (bus) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
513 "Retrieve all services which correspond to a known name in BUS. |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
514 A service has a known name if it doesn't start with \":\"." |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
515 (let (result) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
516 (dolist (name (dbus-list-names bus) result) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
517 (unless (string-equal ":" (substring name 0 1)) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
518 (add-to-list 'result name 'append))))) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
519 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
520 (defun dbus-list-queued-owners (bus service) |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
521 "Return the unique names registered at D-Bus BUS and queued for SERVICE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
522 The result is a list of strings, or `nil' when there are no |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
523 queued name owners service names at all." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
524 (dbus-ignore-errors |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
525 (dbus-call-method |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
526 bus dbus-service-dbus dbus-path-dbus |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
527 dbus-interface-dbus "ListQueuedOwners" service))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
528 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
529 (defun dbus-get-name-owner (bus service) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
530 "Return the name owner of SERVICE registered at D-Bus BUS. |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
531 The result is either a string, or `nil' if there is no name owner." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
532 (dbus-ignore-errors |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
533 (dbus-call-method |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
534 bus dbus-service-dbus dbus-path-dbus |
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
535 dbus-interface-dbus "GetNameOwner" service))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
536 |
104602
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
537 (defun dbus-ping (bus service &optional timeout) |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
538 "Check whether SERVICE is registered for D-Bus BUS. |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
539 TIMEOUT, a nonnegative integer, specifies the maximum number of |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
540 milliseconds `dbus-ping' must return. The default value is 25,000. |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
541 |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
542 Note, that this autoloads SERVICE if it is not running yet. If |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
543 it shall be checked whether SERVICE is already running, one shall |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
544 apply |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
545 |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
546 \(member service \(dbus-list-known-names bus))" |
91588
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
547 ;; "Ping" raises a D-Bus error if SERVICE does not exist. |
91589
12b2f1526656
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91588
diff
changeset
|
548 ;; Otherwise, it returns silently with `nil'. |
91588
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
549 (condition-case nil |
91589
12b2f1526656
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91588
diff
changeset
|
550 (not |
104602
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
551 (if (natnump timeout) |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
552 (dbus-call-method |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
553 bus service dbus-path-dbus dbus-interface-peer |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
554 "Ping" :timeout timeout) |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
555 (dbus-call-method |
d74b934b16e5
* net/dbus.el (dbus-ping): Add optional parameter TIMEOUT.
Michael Albinus <michael.albinus@gmx.de>
parents:
104382
diff
changeset
|
556 bus service dbus-path-dbus dbus-interface-peer "Ping"))) |
91588
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
557 (dbus-error nil))) |
83afe69ce25e
* net/dbus.el (dbus-interface-peer): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
91484
diff
changeset
|
558 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
559 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
560 ;;; D-Bus introspection. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
561 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
562 (defun dbus-introspect (bus service path) |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
563 "Return all interfaces and sub-nodes of SERVICE, |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
564 registered at object path PATH at bus BUS. |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
565 |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
566 BUS is either a Lisp symbol, `:system' or `:session', or a string |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
567 denoting the bus address. SERVICE must be a known service name, |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
568 and PATH must be a valid object path. The last two parameters |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
569 are strings. The result, the introspection data, is a string in |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
570 XML format." |
97692
2a8cbdcbe61d
* net/dbus.el (dbus-introspect): Use `dbus-call-method-non-blocking'.
Michael Albinus <michael.albinus@gmx.de>
parents:
97261
diff
changeset
|
571 ;; We don't want to raise errors. `dbus-call-method-non-blocking' |
2a8cbdcbe61d
* net/dbus.el (dbus-introspect): Use `dbus-call-method-non-blocking'.
Michael Albinus <michael.albinus@gmx.de>
parents:
97261
diff
changeset
|
572 ;; is used, because the handler can be registered in our Emacs |
2a8cbdcbe61d
* net/dbus.el (dbus-introspect): Use `dbus-call-method-non-blocking'.
Michael Albinus <michael.albinus@gmx.de>
parents:
97261
diff
changeset
|
573 ;; instance; caller an callee would block each other. |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
574 (dbus-ignore-errors |
107255
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
575 (funcall |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
576 (if noninteractive 'dbus-call-method 'dbus-call-method-non-blocking) |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
577 bus service path dbus-interface-introspectable "Introspect"))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
578 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
579 (defun dbus-introspect-xml (bus service path) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
580 "Return the introspection data of SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
581 The data are a parsed list. The root object is a \"node\", |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
582 representing the object path PATH. The root object can contain |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
583 \"interface\" and further \"node\" objects." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
584 ;; We don't want to raise errors. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
585 (xml-node-name |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
586 (ignore-errors |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
587 (with-temp-buffer |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
588 (insert (dbus-introspect bus service path)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
589 (xml-parse-region (point-min) (point-max)))))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
590 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
591 (defun dbus-introspect-get-attribute (object attribute) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
592 "Return the ATTRIBUTE value of D-Bus introspection OBJECT. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
593 ATTRIBUTE must be a string according to the attribute names in |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
594 the D-Bus specification." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
595 (xml-get-attribute-or-nil object (intern attribute))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
596 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
597 (defun dbus-introspect-get-node-names (bus service path) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
598 "Return all node names of SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
599 It returns a list of strings. The node names stand for further |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
600 object paths of the D-Bus service." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
601 (let ((object (dbus-introspect-xml bus service path)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
602 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
603 (dolist (elt (xml-get-children object 'node) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
604 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
605 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
606 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
607 (defun dbus-introspect-get-all-nodes (bus service path) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
608 "Return all node names of SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
609 It returns a list of strings, which are further object paths of SERVICE." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
610 (let ((result (list path))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
611 (dolist (elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
612 (dbus-introspect-get-node-names bus service path) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
613 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
614 (setq elt (expand-file-name elt path)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
615 (setq result |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
616 (append result (dbus-introspect-get-all-nodes bus service elt)))))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
617 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
618 (defun dbus-introspect-get-interface-names (bus service path) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
619 "Return all interface names of SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
620 It returns a list of strings. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
621 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
622 There will be always the default interface |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
623 \"org.freedesktop.DBus.Introspectable\". Another default |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
624 interface is \"org.freedesktop.DBus.Properties\". If present, |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
625 \"interface\" objects can also have \"property\" objects as |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
626 children, beside \"method\" and \"signal\" objects." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
627 (let ((object (dbus-introspect-xml bus service path)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
628 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
629 (dolist (elt (xml-get-children object 'interface) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
630 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
631 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
632 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
633 (defun dbus-introspect-get-interface (bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
634 "Return the INTERFACE of SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
635 The return value is an XML object. INTERFACE must be a string, |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
636 element of the list returned by `dbus-introspect-get-interface-names'. |
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
637 The resulting \"interface\" object can contain \"method\", \"signal\", |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
638 \"property\" and \"annotation\" children." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
639 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
640 (dbus-introspect-xml bus service path) 'interface))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
641 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
642 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
643 interface |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
644 (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
645 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
646 (car elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
647 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
648 (defun dbus-introspect-get-method-names (bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
649 "Return a list of strings of all method names of INTERFACE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
650 SERVICE is a service of D-Bus BUS at object path PATH." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
651 (let ((object (dbus-introspect-get-interface bus service path interface)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
652 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
653 (dolist (elt (xml-get-children object 'method) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
654 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
655 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
656 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
657 (defun dbus-introspect-get-method (bus service path interface method) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
658 "Return method METHOD of interface INTERFACE as XML object. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
659 It must be located at SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
660 METHOD must be a string, element of the list returned by |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
661 `dbus-introspect-get-method-names'. The resulting \"method\" |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
662 object can contain \"arg\" and \"annotation\" children." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
663 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
664 (dbus-introspect-get-interface bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
665 'method))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
666 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
667 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
668 method (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
669 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
670 (car elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
671 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
672 (defun dbus-introspect-get-signal-names (bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
673 "Return a list of strings of all signal names of INTERFACE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
674 SERVICE is a service of D-Bus BUS at object path PATH." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
675 (let ((object (dbus-introspect-get-interface bus service path interface)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
676 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
677 (dolist (elt (xml-get-children object 'signal) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
678 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
679 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
680 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
681 (defun dbus-introspect-get-signal (bus service path interface signal) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
682 "Return signal SIGNAL of interface INTERFACE as XML object. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
683 It must be located at SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
684 SIGNAL must be a string, element of the list returned by |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
685 `dbus-introspect-get-signal-names'. The resulting \"signal\" |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
686 object can contain \"arg\" and \"annotation\" children." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
687 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
688 (dbus-introspect-get-interface bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
689 'signal))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
690 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
691 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
692 signal (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
693 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
694 (car elt))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
695 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
696 (defun dbus-introspect-get-property-names (bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
697 "Return a list of strings of all property names of INTERFACE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
698 SERVICE is a service of D-Bus BUS at object path PATH." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
699 (let ((object (dbus-introspect-get-interface bus service path interface)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
700 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
701 (dolist (elt (xml-get-children object 'property) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
702 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
703 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
704 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
705 (defun dbus-introspect-get-property (bus service path interface property) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
706 "This function returns PROPERTY of INTERFACE as XML object. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
707 It must be located at SERVICE in D-Bus BUS at object path PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
708 PROPERTY must be a string, element of the list returned by |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
709 `dbus-introspect-get-property-names'. The resulting PROPERTY |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
710 object can contain \"annotation\" children." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
711 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
712 (dbus-introspect-get-interface bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
713 'property))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
714 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
715 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
716 property |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
717 (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
718 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
719 (car elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
720 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
721 (defun dbus-introspect-get-annotation-names |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
722 (bus service path interface &optional name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
723 "Return all annotation names as list of strings. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
724 If NAME is `nil', the annotations are children of INTERFACE, |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
725 otherwise NAME must be a \"method\", \"signal\", or \"property\" |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
726 object, where the annotations belong to." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
727 (let ((object |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
728 (if name |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
729 (or (dbus-introspect-get-method bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
730 (dbus-introspect-get-signal bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
731 (dbus-introspect-get-property bus service path interface name)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
732 (dbus-introspect-get-interface bus service path interface))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
733 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
734 (dolist (elt (xml-get-children object 'annotation) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
735 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
736 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
737 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
738 (defun dbus-introspect-get-annotation |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
739 (bus service path interface name annotation) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
740 "Return ANNOTATION as XML object. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
741 If NAME is `nil', ANNOTATION is a child of INTERFACE, otherwise |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
742 NAME must be the name of a \"method\", \"signal\", or |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
743 \"property\" object, where the ANNOTATION belongs to." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
744 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
745 (if name |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
746 (or (dbus-introspect-get-method |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
747 bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
748 (dbus-introspect-get-signal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
749 bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
750 (dbus-introspect-get-property |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
751 bus service path interface name)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
752 (dbus-introspect-get-interface bus service path interface)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
753 'annotation))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
754 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
755 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
756 annotation |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
757 (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
758 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
759 (car elt))) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
760 |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
761 (defun dbus-introspect-get-argument-names (bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
762 "Return a list of all argument names as list of strings. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
763 NAME must be a \"method\" or \"signal\" object. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
764 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
765 Argument names are optional, the function can return `nil' |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
766 therefore, even if the method or signal has arguments." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
767 (let ((object |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
768 (or (dbus-introspect-get-method bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
769 (dbus-introspect-get-signal bus service path interface name))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
770 result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
771 (dolist (elt (xml-get-children object 'arg) result) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
772 (add-to-list |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
773 'result (dbus-introspect-get-attribute elt "name") 'append)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
774 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
775 (defun dbus-introspect-get-argument (bus service path interface name arg) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
776 "Return argument ARG as XML object. |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
777 NAME must be a \"method\" or \"signal\" object. ARG must be a string, |
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
778 element of the list returned by `dbus-introspect-get-argument-names'." |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
779 (let ((elt (xml-get-children |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
780 (or (dbus-introspect-get-method bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
781 (dbus-introspect-get-signal bus service path interface name)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
782 'arg))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
783 (while (and elt |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
784 (not (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
785 arg (dbus-introspect-get-attribute (car elt) "name")))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
786 (setq elt (cdr elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
787 (car elt))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
788 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
789 (defun dbus-introspect-get-signature |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
790 (bus service path interface name &optional direction) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
791 "Return signature of a `method' or `signal', represented by NAME, as string. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
792 If NAME is a `method', DIRECTION can be either \"in\" or \"out\". |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
793 If DIRECTION is `nil', \"in\" is assumed. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
794 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
795 If NAME is a `signal', and DIRECTION is non-`nil', DIRECTION must |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
796 be \"out\"." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
797 ;; For methods, we use "in" as default direction. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
798 (let ((object (or (dbus-introspect-get-method |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
799 bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
800 (dbus-introspect-get-signal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
801 bus service path interface name)))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
802 (when (and (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
803 "method" (dbus-introspect-get-attribute object "name")) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
804 (not (stringp direction))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
805 (setq direction "in")) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
806 ;; In signals, no direction is given. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
807 (when (string-equal "signal" (dbus-introspect-get-attribute object "name")) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
808 (setq direction nil)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
809 ;; Collect the signatures. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
810 (mapconcat |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
811 '(lambda (x) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
812 (let ((arg (dbus-introspect-get-argument |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
813 bus service path interface name x))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
814 (if (or (not (stringp direction)) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
815 (string-equal |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
816 direction |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
817 (dbus-introspect-get-attribute arg "direction"))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
818 (dbus-introspect-get-attribute arg "type") |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
819 ""))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
820 (dbus-introspect-get-argument-names bus service path interface name) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
821 ""))) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
822 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
823 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
824 ;;; D-Bus properties. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
825 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
826 (defun dbus-get-property (bus service path interface property) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
827 "Return the value of PROPERTY of INTERFACE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
828 It will be checked at BUS, SERVICE, PATH. The result can be any |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
829 valid D-Bus value, or `nil' if there is no PROPERTY." |
87885
b560a1744534
* net/dbus.el (dbus-ignore-errors): New macro.
Michael Albinus <michael.albinus@gmx.de>
parents:
87586
diff
changeset
|
830 (dbus-ignore-errors |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
831 ;; "Get" returns a variant, so we must use the `car'. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
832 (car |
107255
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
833 (funcall |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
834 (if noninteractive 'dbus-call-method 'dbus-call-method-non-blocking) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
835 bus service path dbus-interface-properties |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
836 "Get" :timeout 500 interface property)))) |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
837 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
838 (defun dbus-set-property (bus service path interface property value) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
839 "Set value of PROPERTY of INTERFACE to VALUE. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
840 It will be checked at BUS, SERVICE, PATH. When the value has |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
841 been set successful, the result is VALUE. Otherwise, `nil' is |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
842 returned." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
843 (dbus-ignore-errors |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
844 ;; "Set" requires a variant. |
107255
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
845 (funcall |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
846 (if noninteractive 'dbus-call-method 'dbus-call-method-non-blocking) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
847 bus service path dbus-interface-properties |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
848 "Set" :timeout 500 interface property (list :variant value)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
849 ;; Return VALUE. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
850 (dbus-get-property bus service path interface property))) |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
851 |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
852 (defun dbus-get-all-properties (bus service path interface) |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
853 "Return all properties of INTERFACE at BUS, SERVICE, PATH. |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
854 The result is a list of entries. Every entry is a cons of the |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
855 name of the property, and its value. If there are no properties, |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
856 `nil' is returned." |
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
857 (dbus-ignore-errors |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
858 ;; "GetAll" returns "a{sv}". |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
859 (let (result) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
860 (dolist (dict |
107255
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
861 (funcall |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
862 (if noninteractive |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
863 'dbus-call-method |
6ea11661a516
* net/dbus.el (dbus-introspect, dbus-get-property)
Michael Albinus <albinus@detlef>
parents:
106815
diff
changeset
|
864 'dbus-call-method-non-blocking) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
865 bus service path dbus-interface-properties |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
866 "GetAll" :timeout 500 interface) |
96801
282e0881421e
* net/dbus.el (dbus-interface-properties): New defconst.
Michael Albinus <michael.albinus@gmx.de>
parents:
94677
diff
changeset
|
867 result) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
868 (add-to-list 'result (cons (car dict) (caadr dict)) 'append))))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
869 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
870 (defun dbus-register-property |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
871 (bus service path interface property access value &optional emits-signal) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
872 "Register property PROPERTY on the D-Bus BUS. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
873 |
109962
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
874 BUS is either a Lisp symbol, `:system' or `:session', or a string |
aa3e4f636621
* net/dbus.el: Accept UNIX domain sockets as bus address.
Michael Albinus <michael.albinus@gmx.de>
parents:
109132
diff
changeset
|
875 denoting the bus address. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
876 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
877 SERVICE is the D-Bus service name of the D-Bus. It must be a |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
878 known name. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
879 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
880 PATH is the D-Bus object path SERVICE is registered. INTERFACE |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
881 is the name of the interface used at PATH, PROPERTY is the name |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
882 of the property of INTERFACE. ACCESS indicates, whether the |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
883 property can be changed by other services via D-Bus. It must be |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
884 either the symbol `:read' or `:readwrite'. VALUE is the initial |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
885 value of the property, it can be of any valid type (see |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
886 `dbus-call-method' for details). |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
887 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
888 If PROPERTY already exists on PATH, it will be overwritten. For |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
889 properties with access type `:read' this is the only way to |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
890 change their values. Properties with access type `:readwrite' |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
891 can be changed by `dbus-set-property'. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
892 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
893 The interface \"org.freedesktop.DBus.Properties\" is added to |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
894 PATH, including a default handler for the \"Get\", \"GetAll\" and |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
895 \"Set\" methods of this interface. When EMITS-SIGNAL is non-nil, |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
896 the signal \"PropertiesChanged\" is sent when the property is |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
897 changed by `dbus-set-property'." |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
898 (unless (member access '(:read :readwrite)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
899 (signal 'dbus-error (list "Access type invalid" access))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
900 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
901 ;; Register SERVICE. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
902 (unless (member service (dbus-list-names bus)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
903 (dbus-call-method |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
904 bus dbus-service-dbus dbus-path-dbus dbus-interface-dbus |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
905 "RequestName" service 0)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
906 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
907 ;; Add the handler. We use `dbus-service-emacs' as service name, in |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
908 ;; order to let unregister SERVICE despite of this default handler. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
909 (dbus-register-method |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
910 bus service path dbus-interface-properties "Get" 'dbus-property-handler) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
911 (dbus-register-method |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
912 bus service path dbus-interface-properties "GetAll" 'dbus-property-handler) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
913 (dbus-register-method |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
914 bus service path dbus-interface-properties "Set" 'dbus-property-handler) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
915 |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
916 ;; Send the PropertiesChanged signal. |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
917 (when emits-signal |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
918 (dbus-send-signal |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
919 bus service path dbus-interface-properties "PropertiesChanged" |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
920 (list (list :dict-entry property (list :variant value))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
921 '(:array))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
922 |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
923 ;; Create a hash table entry. We use nil for the unique name, |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
924 ;; because the property might be accessed from anybody. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
925 (let ((key (list bus interface property)) |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
926 (val |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
927 (list |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
928 (list |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
929 nil service path |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
930 (cons |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
931 (if emits-signal (list access :emits-signal) (list access)) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
932 value))))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
933 (puthash key val dbus-registered-objects-table) |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
934 |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
935 ;; Return the object. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
936 (list key (list service path)))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
937 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
938 (defun dbus-property-handler (&rest args) |
108938
319b48a599cf
* net/dbus.el: Fix typos and declare function.
Juanma Barranquero <lekktu@gmail.com>
parents:
107255
diff
changeset
|
939 "Default handler for the \"org.freedesktop.DBus.Properties\" interface. |
106050
533b0628d222
* net/dbus.el (dbus-unregister-service): New defun.
Michael Albinus <michael.albinus@gmx.de>
parents:
105987
diff
changeset
|
940 It will be registered for all objects created by `dbus-register-object'." |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
941 (let ((bus (dbus-event-bus-name last-input-event)) |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
942 (service (dbus-event-service-name last-input-event)) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
943 (path (dbus-event-path-name last-input-event)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
944 (method (dbus-event-member-name last-input-event)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
945 (interface (car args)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
946 (property (cadr args))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
947 (cond |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
948 ;; "Get" returns a variant. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
949 ((string-equal method "Get") |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
950 (let ((entry (gethash (list bus interface property) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
951 dbus-registered-objects-table))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
952 (when (string-equal path (nth 2 (car entry))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
953 (list (list :variant (cdar (last (car entry)))))))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
954 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
955 ;; "Set" expects a variant. |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
956 ((string-equal method "Set") |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
957 (let* ((value (caar (cddr args))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
958 (entry (gethash (list bus interface property) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
959 dbus-registered-objects-table)) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
960 ;; The value of the hash table is a list; in case of |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
961 ;; properties it contains just one element (UNAME SERVICE |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
962 ;; PATH OBJECT). OBJECT is a cons cell of a list, which |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
963 ;; contains a list of annotations (like :read, |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
964 ;; :read-write, :emits-signal), and the value of the |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
965 ;; property. |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
966 (object (car (last (car entry))))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
967 (unless (consp object) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
968 (signal 'dbus-error |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
969 (list "Property not registered at path" property path))) |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
970 (unless (member :readwrite (car object)) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
971 (signal 'dbus-error |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
972 (list "Property not writable at path" property path))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
973 (puthash (list bus interface property) |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
974 (list (append (butlast (car entry)) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
975 (list (cons (car object) value)))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
976 dbus-registered-objects-table) |
109127
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
977 ;; Send the "PropertiesChanged" signal. |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
978 (when (member :emits-signal (car object)) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
979 (dbus-send-signal |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
980 bus service path dbus-interface-properties "PropertiesChanged" |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
981 (list (list :dict-entry property (list :variant value))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
982 '(:array))) |
6b757d9cacac
* net/dbus.el: Implement signal "PropertiesChanged" (from D-Bus 1.3.1).
Michael Albinus <albinus@detlef>
parents:
108938
diff
changeset
|
983 ;; Return empty reply. |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
984 :ignore)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
985 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
986 ;; "GetAll" returns "a{sv}". |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
987 ((string-equal method "GetAll") |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
988 (let (result) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
989 (maphash |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
990 (lambda (key val) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
991 (when (and (equal (butlast key) (list bus interface)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
992 (string-equal path (nth 2 (car val))) |
106555
98a65639e9cf
* net/dbus.el (dbus-property-handler): Filter lambda forms out
Michael Albinus <michael.albinus@gmx.de>
parents:
106050
diff
changeset
|
993 (not (functionp (car (last (car val)))))) |
105987
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
994 (add-to-list |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
995 'result |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
996 (list :dict-entry |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
997 (car (last key)) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
998 (list :variant (cdar (last (car val)))))))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
999 dbus-registered-objects-table) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
1000 (list result)))))) |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
1001 |
57d249deafab
* net/dbus.el (dbus-registered-objects-table): Renamed from
Michael Albinus <michael.albinus@gmx.de>
parents:
105928
diff
changeset
|
1002 |
104355
7d92d0b5edc6
* net/dbus.el (top): Apply `dbus-init-bus' for the :session bus
Michael Albinus <michael.albinus@gmx.de>
parents:
104337
diff
changeset
|
1003 ;; Initialize :system and :session buses. This adds their file |
7d92d0b5edc6
* net/dbus.el (top): Apply `dbus-init-bus' for the :session bus
Michael Albinus <michael.albinus@gmx.de>
parents:
104337
diff
changeset
|
1004 ;; descriptors to input_wait_mask, in order to detect incoming |
7d92d0b5edc6
* net/dbus.el (top): Apply `dbus-init-bus' for the :session bus
Michael Albinus <michael.albinus@gmx.de>
parents:
104337
diff
changeset
|
1005 ;; messages immediately. |
104382
20810cc73f89
* net/dbus.el (top): Initialize only when `dbusbind' is loaded.
Michael Albinus <michael.albinus@gmx.de>
parents:
104377
diff
changeset
|
1006 (when (featurep 'dbusbind) |
20810cc73f89
* net/dbus.el (top): Initialize only when `dbusbind' is loaded.
Michael Albinus <michael.albinus@gmx.de>
parents:
104377
diff
changeset
|
1007 (dbus-ignore-errors |
20810cc73f89
* net/dbus.el (top): Initialize only when `dbusbind' is loaded.
Michael Albinus <michael.albinus@gmx.de>
parents:
104377
diff
changeset
|
1008 (dbus-init-bus :system) |
20810cc73f89
* net/dbus.el (top): Initialize only when `dbusbind' is loaded.
Michael Albinus <michael.albinus@gmx.de>
parents:
104377
diff
changeset
|
1009 (dbus-init-bus :session))) |
104355
7d92d0b5edc6
* net/dbus.el (top): Apply `dbus-init-bus' for the :session bus
Michael Albinus <michael.albinus@gmx.de>
parents:
104337
diff
changeset
|
1010 |
86941
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
1011 (provide 'dbus) |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
1012 |
cbc23e728425
* net/dbus.el: New file.
Michael Albinus <michael.albinus@gmx.de>
parents:
diff
changeset
|
1013 ;;; dbus.el ends here |