本文整理匯總了Python中dbus.Dictionary方法的典型用法代碼示例。如果您正苦於以下問題:Python dbus.Dictionary方法的具體用法?Python dbus.Dictionary怎麽用?Python dbus.Dictionary使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類dbus
的用法示例。
在下文中一共展示了dbus.Dictionary方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_all
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def test_all(self):
val = [1, 2, 3, 4, 5]
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.Array, val), # noqa
dbus.Array(val))
val = -1
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.Int32, val), # noqa
dbus.Int32(val))
val = 1
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.UInt32, val), # noqa
dbus.UInt32(val))
val = 'Test'
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.String, val), # noqa
dbus.String(val))
val = {'Hello': 1}
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.Dictionary, # noqa
val),
dbus.Dictionary(val))
val = 'True'
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.Boolean, val), # noqa
dbus.Boolean(True))
val = 'False'
self.assertEqual(bt_manager.interface.translate_to_dbus_type(dbus.Boolean, val), # noqa
dbus.Boolean(False))
示例2: create_interface
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def create_interface(self, interface, bridge_interface=None,
driver=None, config_file=None):
try:
wpa_interface = self.__get_interface()
except dbus.exceptions.DBusException as error:
raise ServiceError(error)
else:
args = {"Ifname": interface}
if bridge_interface is not None:
args["BridgeIfname"] = bridge_interface
if driver is not None:
args["Driver"] = driver
if config_file is not None:
args["ConfigFile"] = config_file
try:
return wpa_interface.CreateInterface(dbus.Dictionary(args, 'sv'))
except dbus.exceptions.DBusException as error:
raise InterfaceError(error)
示例3: get_player_properties
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def get_player_properties(self):
return dbus.Dictionary({
'Metadata': self._metadata,
'Rate': 1.0,
'MinimumRate': 1.0,
'MaximumRate': 1.0,
'CanGoNext': True,
'CanGoPrevious': True,
'CanControl': True,
'CanSeek': True,
'CanPause': True,
'CanPlay': True,
'Position': self._old_position,
# 'LoopStatus': 'Playlist',
'PlaybackStatus': to_dbus_playback_status(self._app.player.state),
'Volume': to_dbus_volume(self._app.player.volume),
}, signature='sv', variant_level=2)
# ##########################
# implement mpris2 interface
# ##########################
示例4: dict_to_string
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def dict_to_string(self, d):
# Try to trivially translate a dictionary's elements into nice string
# formatting.
dstr = ""
for key in d:
val = d[key]
str_val = ""
add_string = True
if isinstance(val, dbus.Array):
for elt in val:
if isinstance(elt, dbus.Byte):
str_val += "%s " % int(elt)
elif isinstance(elt, dbus.String):
str_val += "%s" % elt
elif isinstance(val, dbus.Dictionary):
dstr += self.dict_to_string(val)
add_string = False
else:
str_val = val
if add_string:
dstr += "%s: %s\n" % (key, str_val)
return dstr
示例5: unwrap
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def unwrap(val):
if isinstance(val, dbus.ByteArray):
return "".join([str(x) for x in val])
if isinstance(val, (dbus.Array, list, tuple)):
return [unwrap(x) for x in val]
if isinstance(val, (dbus.Dictionary, dict)):
return dict([(unwrap(x), unwrap(y)) for x, y in val.items()])
if isinstance(val, (dbus.Signature, dbus.String)):
return str(val)
if isinstance(val, dbus.Boolean):
return bool(val)
if isinstance(val, (dbus.Int16, dbus.UInt16, dbus.Int32, dbus.UInt32, dbus.Int64, dbus.UInt64)):
return int(val)
if isinstance(val, dbus.Byte):
return bytes([int(val)])
return val
示例6: Set
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def Set(self, interface_name, property_name, value, *args, **kwargs):
"""Standard D-Bus API for setting a property value"""
try:
iface_props = self.props[interface_name]
except KeyError:
raise dbus.exceptions.DBusException(
'no such interface ' + interface_name,
name=self.interface + '.UnknownInterface')
if property_name not in iface_props:
raise dbus.exceptions.DBusException(
'no such property ' + property_name,
name=self.interface + '.UnknownProperty')
iface_props[property_name] = value
self.PropertiesChanged(interface_name,
dbus.Dictionary({property_name: value},
signature='sv'),
dbus.Array([], signature='s'))
示例7: unwrap
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def unwrap(self, val):
if isinstance(val, dbus.ByteArray):
return "".join([str(x) for x in val])
if isinstance(val, (dbus.Array, list, tuple)):
return [self.unwrap(x) for x in val]
if isinstance(val, (dbus.Dictionary, dict)):
return dict([(self.unwrap(x), self.unwrap(y)) for x, y in val.items()])
if isinstance(val, dbus.ObjectPath):
if val.startswith('/org/freedesktop/NetworkManager/'):
classname = val.split('/')[4]
classname = {
'Settings': 'Connection',
'Devices': 'Device',
}.get(classname, classname)
return globals()[classname](val)
if isinstance(val, (dbus.Signature, dbus.String)):
return unicode(val)
if isinstance(val, dbus.Boolean):
return bool(val)
if isinstance(val, (dbus.Int16, dbus.UInt16, dbus.Int32, dbus.UInt32, dbus.Int64, dbus.UInt64)):
return int(val)
if isinstance(val, dbus.Byte):
return bytes([int(val)])
return val
示例8: doCommand
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def doCommand(self,comm):
self.com = comm
#Quit daemon and systray
if self.com == "quit":
#close systray when closing the daemon as well
self.interface.do_quit(True)
print("pomodoro daemon halted")
# Show the change task gui
elif self.com == "systray":
# use busConnection better than bus = dbus.SessionBus() to work with systemd for example
self.bus = dbus.bus.BusConnection(self.dbus_path)
self.session_bus = self.bus.get_object('org.liloman.pomodoro.systray', "/systray")
systray = dbus.Interface(self.session_bus, "org.liloman.pomodoro.systrayInterface")
systray.show_change_task()
# Start a uuid task
elif self.com == "do_start":
if len(sys.argv) != 3:
print("must pass a valid uuid")
sys.exit(1)
dic = dbus.Dictionary({'uuid': sys.argv[2] , 'resume': 'No' } , signature = 'ss' )
try:
print ("reply:"+self.interface.do_start(dic)[0])
except:
print("Incorrect uuid:"+sys.argv[2]+" .The task couldn't be started")
# Do any other command
else:
print(u''.join(self.interface.do_fsm(self.com)[0]).encode('utf-8').strip())
示例9: start
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def start(self):
self.assertEquals(interface.do_start(dbus.Dictionary({'uuid': self.uuid , 'resume': 'No'}))[0],"started:"+self.uuid)
示例10: test_done_current
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def test_done_current(self):
other_task = Task(self.tw, description="task to be done")
other_task.save()
uuid2 = other_task['uuid']
self.assertEquals(interface.do_start(dbus.Dictionary({'uuid': uuid2 , 'resume': 'No'}))[0],"started:"+uuid2)
prog = re.compile('started .* left.*')
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.done_current()[0],"ok")
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.done_current()[0],"no active task")
示例11: test_resume
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def test_resume(self):
self.start()
self.assertEquals(interface.do_fsm("stop")[0],"ok")
self.assertEquals(interface.do_fsm("start")[0],"ok")
prog = re.compile('started .* left.*')
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.do_fsm("pause")[0],"ok")
prog = re.compile('paused .* left.*')
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.do_fsm("start")[0],"ok")
self.assertEquals(interface.do_fsm("start")[0],"Already started")
# test done and resume
other_task = Task(self.tw, description="task 2 for the test")
other_task.save()
uuid2 = other_task['uuid']
self.assertEquals(interface.do_start(dbus.Dictionary({'uuid': uuid2 , 'resume': 'No'}))[0],"started:"+uuid2)
prog = re.compile('started .* left.*')
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.do_fsm("stop")[0],"ok")
other_task.done()
self.assertEquals(interface.do_fsm("start")[0],"ok")
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
# test delete and resume
other_task = Task(self.tw, description="task 3 for the test")
other_task.save()
uuid2 = other_task['uuid']
self.assertEquals(interface.do_start(dbus.Dictionary({'uuid': uuid2 , 'resume': 'No'}))[0],"started:"+uuid2)
prog = re.compile('started .* left.*')
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
self.assertEquals(interface.do_fsm("stop")[0],"ok")
other_task.delete()
self.assertEquals(interface.do_fsm("start")[0],"ok")
self.assertTrue(prog.match(interface.do_fsm("status")[0]))
示例12: mediaEndpointRegisterSBC
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def mediaEndpointRegisterSBC(self):
media = dbus.Interface(self.bus.get_object("org.bluez", self.path), "org.bluez.Media1")
media_path = '/test/endpoint_sbc_' + self.path.split('/')[3]
self.mediaEndpointSBC = MediaEndpoint(self.bus, media_path)
properties = dbus.Dictionary({ "UUID" : A2DP_SINK_UUID, "Codec" : SBC_CODEC, "DelayReporting" : True, "Capabilities" : SBC_CAPABILITIES })
media.RegisterEndpoint(media_path, properties)
print("MediaEndpoint SBC registered for " + self.path)
示例13: mediaEndpointRegisterAAC
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def mediaEndpointRegisterAAC(self):
media = dbus.Interface(self.bus.get_object("org.bluez", self.path), "org.bluez.Media1")
media_path = '/test/endpoint_aac_' + self.path.split('/')[3]
self.mediaEndpointAAC = MediaEndpoint(self.bus, media_path)
properties = dbus.Dictionary({ "UUID" : A2DP_SINK_UUID, "Codec" : AAC_CODEC, "DelayReporting" : True, "Capabilities" : AAC_CAPABILITIES })
media.RegisterEndpoint(media_path, properties)
print("MediaEndpoint AAC registered for " + self.path)
示例14: song_changed
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def song_changed(self, artists=None, album=None, title=None,
album_art=None):
"""song_changed - sets the info for the current song.
This method is not typically overriden. It should be called
by implementations of this class when the player has changed
songs.
named arguments:
artists - a list of strings representing the artists"
album - a string for the name of the album
title - a string for the title of the song
"""
if artists is None:
artists = ["Artist Unknown"]
if album is None:
album = "Album Uknown"
if title is None:
title = "Title Uknown"
if album_art is None:
album_art = ""
self.__meta_data = dbus.Dictionary({"xesam:album": album,
"xesam:title": title,
"xesam:artist": artists,
"mpris:artUrl": album_art,
}, "sv", variant_level=1)
示例15: signal_playing
# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import Dictionary [as 別名]
def signal_playing(self):
"""signal_playing - Tell the Sound Menu that the player has
started playing. Implementations many need to call this function in
order to keep the Sound Menu in synch.
arguments:
none
"""
self.__playback_status = "Playing"
d = dbus.Dictionary({"PlaybackStatus": self.__playback_status,
"Metadata": self.__meta_data}, "sv",
variant_level=1)
self.PropertiesChanged("org.mpris.MediaPlayer2.Player", d, [])