[tor-commits] [arm/master] Support boolean conf options.
atagar at torproject.org
atagar at torproject.org
Thu Aug 11 15:27:57 UTC 2011
commit ac0278521e4d71348ec68776112a9fb55497d02d
Author: Kamran Riaz Khan <krkhan at inspirated.com>
Date: Wed Jul 27 07:15:23 2011 +0500
Support boolean conf options.
---
src/gui/configPanel.py | 6 ++++++
src/util/gtkTools.py | 31 +++++++++++++++++++++++++++++++
2 files changed, 37 insertions(+), 0 deletions(-)
diff --git a/src/gui/configPanel.py b/src/gui/configPanel.py
index a1d1daa..7b1ea42 100644
--- a/src/gui/configPanel.py
+++ b/src/gui/configPanel.py
@@ -17,6 +17,10 @@ def inputConfValueText(option):
prompt = "Enter value for %s" % option
return gtkTools.inputText(prompt)
+def inputConfValueBoolean(option):
+ prompt = "Select value for %s" % option
+ return "1" if gtkTools.inputBoolean(prompt) else "0"
+
class ConfContents(gtkTools.ListWrapper):
def _create_row_from_value(self, entry):
option = entry.get(Field.OPTION)
@@ -77,6 +81,8 @@ class ConfigPanel(object, CliConfigPanel):
if configType == 'DataSize':
newValue = inputConfValueText(configOption)
+ elif configType == 'Boolean':
+ newValue = inputConfValueBoolean(configOption)
if newValue:
try:
diff --git a/src/util/gtkTools.py b/src/util/gtkTools.py
index 5180e82..cc2d361 100644
--- a/src/util/gtkTools.py
+++ b/src/util/gtkTools.py
@@ -125,6 +125,37 @@ def inputText(prompt):
return text if response == gtk.RESPONSE_OK else None
+def inputBoolean(prompt):
+ dialog = gtk.MessageDialog(None,
+ gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT,
+ gtk.MESSAGE_QUESTION,
+ gtk.BUTTONS_OK_CANCEL,
+ None)
+
+ dialog.set_markup(prompt)
+
+ hbox = gtk.HBox()
+ buttonTrue = gtk.RadioButton(None, "True")
+ buttonFalse = gtk.RadioButton(buttonTrue, "False")
+ hbox.pack_start(buttonTrue, True, True, 0)
+ hbox.pack_start(buttonFalse, True, True, 0)
+
+ dialog.vbox.pack_end(hbox, True, True, 0)
+
+ dialog.show_all()
+ response = dialog.run()
+
+ choice = None
+
+ if buttonTrue.get_active():
+ choice = True
+ elif buttonFalse.get_active():
+ choice = False
+
+ dialog.destroy()
+
+ return choice if response == gtk.RESPONSE_OK else None
+
def showError(msg):
dialog = gtk.MessageDialog(None,
gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT,
More information about the tor-commits
mailing list