2003-04-05 15:38:48 +02:00
|
|
|
###
|
2004-08-23 15:14:06 +02:00
|
|
|
# Copyright (c) 2002-2004, Jeremiah Fincher
|
2003-04-05 15:38:48 +02:00
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions are met:
|
|
|
|
#
|
|
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer.
|
|
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
# * Neither the name of the author of this software nor the name of
|
|
|
|
# contributors to this software may be used to endorse or promote products
|
|
|
|
# derived from this software without specific prior written consent.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
###
|
|
|
|
|
2003-10-04 15:07:15 +02:00
|
|
|
"""Handles interactive questions; useful for wizards and whatnot."""
|
|
|
|
|
2003-11-25 18:33:58 +01:00
|
|
|
__revision__ = "$Id$"
|
|
|
|
|
2004-01-19 18:44:50 +01:00
|
|
|
import sys
|
2003-08-29 00:55:22 +02:00
|
|
|
import textwrap
|
2003-11-17 05:13:06 +01:00
|
|
|
from getpass import getpass as getPass
|
2003-08-29 00:55:22 +02:00
|
|
|
|
2004-07-24 07:18:26 +02:00
|
|
|
import supybot.ansi as ansi
|
|
|
|
import supybot.utils as utils
|
2004-01-19 18:44:50 +01:00
|
|
|
|
2004-01-20 12:53:34 +01:00
|
|
|
useBold = False
|
2004-01-19 18:44:50 +01:00
|
|
|
|
2004-08-23 14:27:23 +02:00
|
|
|
def output(s, unformatted=True, fd=sys.stdout):
|
2004-01-19 18:44:50 +01:00
|
|
|
if unformatted:
|
2004-06-19 21:02:06 +02:00
|
|
|
s = textwrap.fill(utils.normalizeWhitespace(s), width=65)
|
2004-08-23 14:27:23 +02:00
|
|
|
print >>fd, s
|
|
|
|
print >>fd
|
2004-01-19 18:44:50 +01:00
|
|
|
|
2004-02-23 11:50:40 +01:00
|
|
|
def expect(prompt, possibilities, recursed=False, default=None,
|
2004-08-23 14:27:23 +02:00
|
|
|
acceptEmpty=False, fd=sys.stdout):
|
2003-10-04 15:07:15 +02:00
|
|
|
"""Prompt the user with prompt, allow them to choose from possibilities.
|
|
|
|
|
|
|
|
If possibilities is empty, allow anything.
|
|
|
|
"""
|
2004-01-22 20:53:04 +01:00
|
|
|
prompt = utils.normalizeWhitespace(prompt)
|
2003-08-19 15:36:14 +02:00
|
|
|
originalPrompt = prompt
|
2003-04-05 15:38:48 +02:00
|
|
|
if recursed:
|
2004-01-20 12:53:34 +01:00
|
|
|
output('Sorry, that response was not an option.')
|
2004-08-11 14:54:56 +02:00
|
|
|
if useBold:
|
|
|
|
choices = '[%s%%s%s]' % (ansi.RESET, ansi.BOLD)
|
|
|
|
else:
|
|
|
|
choices = '[%s]'
|
2003-04-05 15:38:48 +02:00
|
|
|
if possibilities:
|
2004-08-11 14:54:56 +02:00
|
|
|
prompt = '%s %s' % (originalPrompt, choices % '/'.join(possibilities))
|
2003-09-25 09:15:10 +02:00
|
|
|
if len(prompt) > 70:
|
2004-08-11 14:54:56 +02:00
|
|
|
prompt = '%s %s' % (originalPrompt, choices % '/ '.join(possibilities))
|
2004-01-19 18:44:50 +01:00
|
|
|
if default is not None:
|
|
|
|
prompt = '%s (default: %s)' % (prompt, default)
|
2004-02-23 11:50:40 +01:00
|
|
|
prompt = textwrap.fill(prompt)
|
2003-08-29 01:03:09 +02:00
|
|
|
prompt = prompt.replace('/ ', '/')
|
2003-04-05 15:38:48 +02:00
|
|
|
prompt = prompt.strip() + ' '
|
2004-01-20 12:53:34 +01:00
|
|
|
if useBold:
|
2004-08-23 14:27:23 +02:00
|
|
|
print >>fd, ansi.BOLD,
|
2003-04-05 15:38:48 +02:00
|
|
|
s = raw_input(prompt)
|
2004-01-20 12:53:34 +01:00
|
|
|
if useBold:
|
2004-08-23 14:27:23 +02:00
|
|
|
print >>fd, ansi.RESET
|
2003-08-28 19:55:47 +02:00
|
|
|
s = s.strip()
|
2004-08-23 14:27:23 +02:00
|
|
|
print >>fd
|
2003-04-05 15:38:48 +02:00
|
|
|
if possibilities:
|
|
|
|
if s in possibilities:
|
2003-08-28 19:55:47 +02:00
|
|
|
return s
|
2004-01-19 18:44:50 +01:00
|
|
|
elif not s and default is not None:
|
|
|
|
return default
|
2004-02-09 20:01:47 +01:00
|
|
|
elif not s and acceptEmpty:
|
|
|
|
return s
|
2003-04-05 15:38:48 +02:00
|
|
|
else:
|
2003-11-12 23:24:50 +01:00
|
|
|
return expect(originalPrompt, possibilities, recursed=True,
|
2004-02-23 11:50:40 +01:00
|
|
|
default=default)
|
2003-04-05 15:38:48 +02:00
|
|
|
else:
|
2004-01-19 18:44:50 +01:00
|
|
|
if not s and default is not None:
|
|
|
|
return default
|
2003-04-05 15:38:48 +02:00
|
|
|
return s.strip()
|
|
|
|
|
|
|
|
def anything(prompt):
|
2003-10-04 15:07:15 +02:00
|
|
|
"""Allow anything from the user."""
|
2003-04-05 15:38:48 +02:00
|
|
|
return expect(prompt, [])
|
|
|
|
|
2004-01-19 18:44:50 +01:00
|
|
|
def something(prompt, default=None):
|
2003-10-04 15:07:15 +02:00
|
|
|
"""Allow anything *except* nothing from the user."""
|
2004-01-19 18:44:50 +01:00
|
|
|
s = expect(prompt, [], default=default)
|
2003-04-08 09:22:40 +02:00
|
|
|
while not s:
|
2004-01-20 12:53:34 +01:00
|
|
|
output('Sorry, you must enter a value.')
|
2004-01-19 18:44:50 +01:00
|
|
|
s = expect(prompt, [], default=default)
|
2003-04-08 09:22:40 +02:00
|
|
|
return s
|
|
|
|
|
2004-01-19 18:44:50 +01:00
|
|
|
def yn(prompt, default=None):
|
2003-10-04 15:07:15 +02:00
|
|
|
"""Allow only 'y' or 'n' from the user."""
|
2004-01-19 18:44:50 +01:00
|
|
|
if default is not None:
|
|
|
|
if default:
|
|
|
|
default = 'y'
|
|
|
|
else:
|
|
|
|
default = 'n'
|
2004-02-23 11:50:40 +01:00
|
|
|
s = expect(prompt, ['y', 'n'], default=default)
|
2004-01-19 18:44:50 +01:00
|
|
|
if s is 'y':
|
|
|
|
return True
|
2004-01-20 12:53:34 +01:00
|
|
|
else:
|
|
|
|
return False
|
2003-04-05 15:38:48 +02:00
|
|
|
|
2004-04-16 09:36:09 +02:00
|
|
|
def getpass(prompt='Enter password: ', secondPrompt='Re-enter password: '):
|
2004-01-19 18:44:50 +01:00
|
|
|
"""Prompt the user for a password."""
|
2003-11-17 05:13:06 +01:00
|
|
|
password = ''
|
2004-04-16 09:36:09 +02:00
|
|
|
secondPassword = ' ' # Note that this should be different than password.
|
2003-11-17 05:13:06 +01:00
|
|
|
assert prompt
|
|
|
|
if not prompt[-1].isspace():
|
|
|
|
prompt += ' '
|
|
|
|
while True:
|
2004-01-20 12:53:34 +01:00
|
|
|
if useBold:
|
2004-01-19 18:44:50 +01:00
|
|
|
sys.stdout.write(ansi.BOLD)
|
2003-11-17 05:13:06 +01:00
|
|
|
password = getPass(prompt)
|
2004-04-16 09:36:09 +02:00
|
|
|
secondPassword = getPass(secondPrompt)
|
2004-01-20 12:53:34 +01:00
|
|
|
if useBold:
|
2004-01-19 18:44:50 +01:00
|
|
|
print ansi.RESET
|
2004-04-16 09:36:09 +02:00
|
|
|
if password != secondPassword:
|
2004-01-20 12:53:34 +01:00
|
|
|
output('Passwords don\'t match.')
|
2003-11-17 05:13:06 +01:00
|
|
|
else:
|
|
|
|
break
|
|
|
|
return password
|
|
|
|
|
2003-05-27 22:03:37 +02:00
|
|
|
|
2003-10-04 15:07:15 +02:00
|
|
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|