2003-03-25 08:13:59 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
###
|
|
|
|
# Copyright (c) 2002, Jeremiah Fincher
|
|
|
|
# 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.
|
|
|
|
###
|
|
|
|
|
|
|
|
def expect(prompt, possibilities, recursed=False):
|
|
|
|
if recursed:
|
|
|
|
print 'Sorry, that response was not an option.'
|
2003-03-27 07:00:31 +01:00
|
|
|
if possibilities:
|
|
|
|
prompt = '%s [%s]' % (prompt, '/'.join(possibilities))
|
|
|
|
prompt = prompt.strip() + ' '
|
|
|
|
s = raw_input(prompt)
|
2003-03-25 08:13:59 +01:00
|
|
|
if possibilities:
|
|
|
|
if s in possibilities:
|
2003-03-27 07:00:31 +01:00
|
|
|
return s.strip()
|
2003-03-25 08:13:59 +01:00
|
|
|
else:
|
2003-03-27 07:00:31 +01:00
|
|
|
return expect(prompt, possibilities, recursed=True)
|
2003-03-25 08:13:59 +01:00
|
|
|
else:
|
2003-03-27 07:00:31 +01:00
|
|
|
return s.strip()
|
|
|
|
|
|
|
|
def anything(prompt):
|
|
|
|
return expect(prompt, [])
|
|
|
|
|
|
|
|
def yn(prompt):
|
|
|
|
return expect(prompt, ['y', 'n'])
|
|
|
|
|
|
|
|
def ny(prompt):
|
|
|
|
return expect(prompt, ['n', 'y'])
|
2003-03-25 08:13:59 +01:00
|
|
|
|
|
|
|
# So we gotta:
|
|
|
|
# Check to see if the user has sqlite installed.
|
|
|
|
# Get the owner's user name and password
|
|
|
|
# Provide a list of modules to load by default.
|
|
|
|
# See what other commands the user would like to run by default.
|
|
|
|
# Go through conf.py options and see which ones the user would like.
|
2003-03-27 07:00:31 +01:00
|
|
|
import sys
|
|
|
|
sys.path.insert(0, 'src')
|
|
|
|
from fix import *
|
|
|
|
import os
|
|
|
|
import imp
|
|
|
|
import conf
|
|
|
|
sys.path.insert(0, conf.pluginDir)
|
|
|
|
if __name__ == '__main__':
|
2003-03-27 07:28:13 +01:00
|
|
|
name = anything('What would you like to name your config file?')
|
|
|
|
if not name.endswith('.conf'):
|
|
|
|
name += '.conf'
|
2003-03-27 07:00:31 +01:00
|
|
|
configfd = file(os.path.join(conf.confDir, name), 'w')
|
|
|
|
server = anything('What server would you like to connect to?')
|
|
|
|
if ny('Does that server require connection on a non-standard port?')=='y':
|
|
|
|
server = ':'.join(server, anything('What port is that?'))
|
|
|
|
configfd.write('Server: %s\n' % server)
|
|
|
|
nick = anything('What nick would you like the bot to use?')
|
|
|
|
configfd.write('Nick: %s\n' % nick)
|
|
|
|
configfd.write('\n')
|
2003-03-27 07:51:34 +01:00
|
|
|
configfd.write('load AdminCommands\n')
|
|
|
|
configfd.write('load UserCommands\n')
|
|
|
|
configfd.write('load ChannelCommands\n')
|
|
|
|
configfd.write('load MiscCommands\n')
|
2003-03-27 07:00:31 +01:00
|
|
|
# Now's where we load the modules.
|
|
|
|
if yn('Would you like to see a list of the available modules?') == 'y':
|
|
|
|
filenames = os.listdir(conf.pluginDir)
|
|
|
|
plugins = []
|
|
|
|
for filename in filenames:
|
|
|
|
if filename.endswith('.py') and \
|
|
|
|
filename.lower() != filename:
|
|
|
|
plugins.append(os.path.splitext(filename)[0])
|
|
|
|
print 'The available plugins are:\n %s' % '\n '.join(plugins)
|
|
|
|
while yn('Would you like to add a plugin?') == 'y':
|
|
|
|
plugin = expect('What plugin?', plugins)
|
|
|
|
moduleInfo = imp.find_module(plugin)
|
|
|
|
module = imp.load_module(plugin, *moduleInfo)
|
|
|
|
print module.__doc__
|
|
|
|
if yn('Would you like to add this plugin?') == 'y':
|
|
|
|
configfd.write('load %s\n' % plugin)
|
2003-03-27 07:28:13 +01:00
|
|
|
preConnect = 'Would you like any commands to run ' \
|
|
|
|
'before the bot connects to the server?'
|
|
|
|
while yn(preConnect) == 'y':
|
|
|
|
preConnect = 'Would you like any other commands ' \
|
|
|
|
'to run before the bot connects to the server?'
|
2003-03-27 07:00:31 +01:00
|
|
|
configfd.write(anything('What command?'))
|
|
|
|
configfd.write('\n')
|
|
|
|
configfd.write('\n')
|
2003-03-27 07:28:13 +01:00
|
|
|
postConnect = 'Would you like any commands to run ' \
|
|
|
|
'when the bot is finished connecting to the server?'
|
|
|
|
while yn(postConnect) == 'y':
|
2003-03-27 07:51:34 +01:00
|
|
|
postConnect = 'Would you like any other commands to run ' \
|
2003-03-27 07:28:13 +01:00
|
|
|
'when the bot is finished connecting to the server?'
|
2003-03-27 07:00:31 +01:00
|
|
|
configfd.write(anything('What command?'))
|
|
|
|
configfd.write('\n')
|
|
|
|
configfd.close()
|
|
|
|
print
|
|
|
|
print 'You\'re done! Now run the bot with the command line:'
|
|
|
|
print 'src/bot.py conf/%s.conf' % name
|
|
|
|
print
|
|
|
|
|
2003-03-25 08:13:59 +01:00
|
|
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|