Smarter bundle name matching
This commit is contained in:
parent
d3493aea9e
commit
a5d303f9ff
@ -44,17 +44,28 @@ def _error_cb(handler, err):
|
|||||||
print err
|
print err
|
||||||
gtk.main_quit()
|
gtk.main_quit()
|
||||||
|
|
||||||
|
def print_help(self):
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
_setup_bus_address()
|
_setup_bus_address()
|
||||||
|
|
||||||
service_name = sys.argv[1]
|
bundle = None
|
||||||
registry = bundleregistry.get_registry()
|
|
||||||
bundle = registry.get_bundle(service_name)
|
if len(sys.argv) > 1:
|
||||||
|
registry = bundleregistry.get_registry()
|
||||||
|
bundle = registry.find_bundle(sys.argv[1])
|
||||||
|
|
||||||
|
if bundle == None:
|
||||||
|
print 'Usage:\n\n' \
|
||||||
|
'sugar-activity [bundle]\n\n' \
|
||||||
|
'Bundle can be a part of the service name or of bundle name.'
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
bus = dbus.SessionBus()
|
bus = dbus.SessionBus()
|
||||||
bus_object = bus.get_object('org.freedesktop.DBus', '/org/freedesktop/DBus')
|
bus_object = bus.get_object('org.freedesktop.DBus', '/org/freedesktop/DBus')
|
||||||
try:
|
try:
|
||||||
name = bus_object.GetNameOwner(
|
name = bus_object.GetNameOwner(
|
||||||
service_name, dbus_interface='org.freedesktop.DBus')
|
bundle.get_service_name(), dbus_interface='org.freedesktop.DBus')
|
||||||
except dbus.DBusException:
|
except dbus.DBusException:
|
||||||
name = None
|
name = None
|
||||||
|
|
||||||
@ -63,7 +74,7 @@ if name:
|
|||||||
else:
|
else:
|
||||||
activityfactoryservice.run(bundle.get_path())
|
activityfactoryservice.run(bundle.get_path())
|
||||||
|
|
||||||
handler = activityfactory.create(service_name)
|
handler = activityfactory.create(bundle.get_service_name())
|
||||||
handler.connect('success', _success_cb, name != None)
|
handler.connect('success', _success_cb, name != None)
|
||||||
handler.connect('error', _error_cb)
|
handler.connect('error', _error_cb)
|
||||||
|
|
||||||
|
@ -41,6 +41,18 @@ class BundleRegistry(gobject.GObject):
|
|||||||
self._search_path = []
|
self._search_path = []
|
||||||
self._service_manager = _ServiceManager()
|
self._service_manager = _ServiceManager()
|
||||||
|
|
||||||
|
def find_bundle(self, key):
|
||||||
|
"""Find a bundle in the registry"""
|
||||||
|
key = key.lower()
|
||||||
|
|
||||||
|
for bundle in self._bundles.values():
|
||||||
|
name = bundle.get_name().lower()
|
||||||
|
service_name = bundle.get_service_name().lower()
|
||||||
|
if name.find(key) != -1 or service_name.find(key) != -1:
|
||||||
|
return bundle
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
def get_bundle(self, service_name):
|
def get_bundle(self, service_name):
|
||||||
"""Returns an bundle given his service name"""
|
"""Returns an bundle given his service name"""
|
||||||
if self._bundles.has_key(service_name):
|
if self._bundles.has_key(service_name):
|
||||||
|
Loading…
Reference in New Issue
Block a user