summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaiki Ueno <dueno@src.gnome.org>2015-01-16 17:14:39 +0900
committerDaiki Ueno <dueno@src.gnome.org>2015-01-16 17:49:44 +0900
commit9e1e605a224b14b473c769e926208d157089b525 (patch)
treebfe96b155a92a57674a45fbb14e7d85293a59f7f
parent9af68b2345fedbb66445c9a8c6e3f45d10fb3474 (diff)
downloadcaribou-9e1e605a224b14b473c769e926208d157089b525.tar.gz
antler: Refactor antler-keyboard invocation
-rwxr-xr-xbin/antler-keyboard.in4
-rw-r--r--caribou/antler/main.py33
2 files changed, 27 insertions, 10 deletions
diff --git a/bin/antler-keyboard.in b/bin/antler-keyboard.in
index 941cf91..a1f41a6 100755
--- a/bin/antler-keyboard.in
+++ b/bin/antler-keyboard.in
@@ -38,6 +38,4 @@ else
export ANTLER_THEME_PATH="$(dirname $script_dir)/data"
fi
-@PYTHON@ -c "
-from caribou.antler.main import AntlerKeyboardService
-AntlerKeyboardService().run()"
+@PYTHON@ -m caribou.antler.main "$@"
diff --git a/caribou/antler/main.py b/caribou/antler/main.py
index 24b842a..251678b 100644
--- a/caribou/antler/main.py
+++ b/caribou/antler/main.py
@@ -1,10 +1,14 @@
-from gi.repository import Caribou, GObject
-from window import AntlerWindowEntry
-from keyboard_view import AntlerKeyboardView
+from gi.repository import Caribou, GLib, GObject
+from .window import AntlerWindowEntry
+from .keyboard_view import AntlerKeyboardView
import sys
-class AntlerKeyboardService(Caribou.KeyboardService):
- def __init__(self):
+class AntlerKeyboardCommand(object):
+ def run(self):
+ pass
+
+class AntlerKeyboardService(Caribou.KeyboardService, AntlerKeyboardCommand):
+ def __init__(self, args=None):
GObject.GObject.__init__(self)
self.register_keyboard("Antler")
self.window = AntlerWindowEntry(AntlerKeyboardView)
@@ -30,5 +34,20 @@ class AntlerKeyboardService(Caribou.KeyboardService):
sys.exit(0)
if __name__ == "__main__":
- antler_keyboard_service = AntlerKeyboardService()
- antler_keyboard_service.run()
+ import argparse
+ import signal
+ signal.signal(signal.SIGINT, signal.SIG_DFL)
+
+ GLib.set_prgname('antler-keyboard')
+
+ parser = argparse.ArgumentParser(description='antler-keyboard')
+ parser.add_argument('-c', '--command', type=str, default='service',
+ help='command (service or preview, default: service)')
+ args = parser.parse_args()
+
+ command = globals().get('AntlerKeyboard%s' % args.command.capitalize())
+ if command:
+ command(args).run()
+ else:
+ sys.stderr.write("Unknown command: %s\n" % args.command)
+ sys.exit(1)