From a5d303f9ff96cb17a4fb10e611314e7c1c440c7e Mon Sep 17 00:00:00 2001 From: Marco Pesenti Gritti Date: Fri, 9 Mar 2007 16:55:18 +0100 Subject: [PATCH] Smarter bundle name matching --- shell/sugar-activity | 21 ++++++++++++++++----- sugar/activity/bundleregistry.py | 12 ++++++++++++ 2 files changed, 28 insertions(+), 5 deletions(-) diff --git a/shell/sugar-activity b/shell/sugar-activity index 75aa967f..04fed667 100755 --- a/shell/sugar-activity +++ b/shell/sugar-activity @@ -44,17 +44,28 @@ def _error_cb(handler, err): print err gtk.main_quit() +def print_help(self): + sys.exit(0) + _setup_bus_address() -service_name = sys.argv[1] -registry = bundleregistry.get_registry() -bundle = registry.get_bundle(service_name) +bundle = None + +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_object = bus.get_object('org.freedesktop.DBus', '/org/freedesktop/DBus') try: name = bus_object.GetNameOwner( - service_name, dbus_interface='org.freedesktop.DBus') + bundle.get_service_name(), dbus_interface='org.freedesktop.DBus') except dbus.DBusException: name = None @@ -63,7 +74,7 @@ if name: else: 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('error', _error_cb) diff --git a/sugar/activity/bundleregistry.py b/sugar/activity/bundleregistry.py index 2ad68ed5..7b124921 100644 --- a/sugar/activity/bundleregistry.py +++ b/sugar/activity/bundleregistry.py @@ -41,6 +41,18 @@ class BundleRegistry(gobject.GObject): self._search_path = [] 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): """Returns an bundle given his service name""" if self._bundles.has_key(service_name):