for module in muff.__all__:
exec("import " + module)
-# does the files:commands setting exist yet?
-try:
- if muffconf.get("files", "commands"): pass
-
-# if not, reload the muffconf module
-except AttributeError:
- reload(muffconf)
-
-# now we can safely nab the command path setting and build a list of data files
-command_path = muffconf.get("files", "commands")
-command_files_index = ConfigParser.SafeConfigParser()
-command_files_index.read(command_path + "/index")
-command_files = []
-for each_file in command_files_index.get("index", "files").split():
- command_files.append(command_path + "/" + each_file)
-
-# read the command data files
-command_data = ConfigParser.SafeConfigParser()
-command_data.read(command_files)
-
-# this creates a list of commands mentioned in the data files
-command_list = command_data.sections()
-
def handle_user_input(user):
"""The main handler, branches to a state-specific handler."""
# check to make sure the state is expected, then call that handler
- exec("handler_" + user.state.replace(" ", "_") + "(user)")
+ if "handler_" + user.state in globals():
+ exec("handler_" + user.state + "(user)")
+ else:
+ generic_menu_handler(user)
# since we got input, flag that the menu/prompt needs to be redisplayed
user.menu_seen = False
+ # if the user's client echo is off, send a blank line for aesthetics
+ if not user.echoing: user.send("", "")
+
+def generic_menu_handler(user):
+ """A generic menu choice handler."""
+
+ # get a lower-case representation of the next line of input
+ if user.input_queue:
+ choice = user.input_queue.pop(0)
+ if choice: choice = choice.lower()
+ else: choice = ""
+
+ # run any script related to this choice
+ exec(muffmenu.get_choice_action(user, choice))
+
+ # move on to the next state or return an error
+ new_state = muffmenu.get_choice_branch(user, choice)
+ if new_state: user.state = new_state
+ else: user.error = "default"
+
def handler_entering_account_name(user):
"""Handle the login account name."""
# if we have a password hash, time to request a password
if user.get_passhash():
- user.state = "checking password"
+ user.state = "checking_password"
# otherwise, this could be a brand new user
else:
user.proposed_name = None
user.load()
muffmisc.log("New user: " + user.name)
- user.state = "checking new account name"
+ user.state = "checking_new_account_name"
# if the user entered nothing for a name, then buhbye
else:
if md5.new(user.proposed_name + input_data).hexdigest() == user.passhash:
# if so, set the username and load from cold storage
- # TODO: branch to character creation and selection menus
user.name = user.proposed_name
del(user.proposed_name)
if not user.replace_old_connections():
user.load()
user.authenticate()
- user.state = "active"
+ user.state = "main_utility"
# if at first your hashes don't match, try, try again
elif user.password_tries < muffconf.getint("general", "password_tries"):
user.send("$(eol)$(red)Too many failed password attempts...$(nrm)$(eol)")
user.state = "disconnecting"
-def handler_disconnecting(user):
- """Waiting for the user's connection to close."""
- pass
-
-def handler_disconnecting_duplicates(user):
- """Waiting for duplicate connections to close."""
- pass
-
def handler_checking_new_account_name(user):
"""Handle input for the new user menu."""
# if there's no input, use the default
else:
- choice = muffmenu.get_default(user)
+ choice = muffmenu.get_default_menu_choice(user.state)
# user selected to disconnect
if choice == "d":
# go back to the login screen
elif choice == "g":
- user.state = "entering account name"
+ user.state = "entering_account_name"
# new user, so ask for a password
elif choice == "n":
- user.state = "entering new password"
+ user.state = "entering_new_password"
# user entered a non-existent option
else:
# hash and store it, then move on to verification
user.passhash = md5.new(user.name + input_data).hexdigest()
- user.state = "verifying new password"
+ user.state = "verifying_new_password"
# the password was weak, try again if you haven't tried too many times
elif user.password_tries < muffconf.getint("general", "password_tries"):
user.save()
# the hashes matched, so go active
- # TODO: branch to character creation and selection menus
- if not user.replace_old_connections(): user.state = "active"
+ if not user.replace_old_connections(): user.state = "main_utility"
# go back to entering the new password as long as you haven't tried
# too many times
elif user.password_tries < muffconf.getint("general", "password_tries"):
user.password_tries += 1
user.error = "differs"
- user.state = "entering new password"
+ user.state = "entering_new_password"
# otherwise, sayonara
else:
command = command.lower()
# the command matches a command word for which we have data
- if command in command_list: exec("command_" + command + "(user, command, parameters)")
+ if command in muffuniv.universe.commands.keys():
+ exec(muffuniv.universe.commands[command].get("action"))
# no data matching the entered command word
elif command: command_error(user, command, parameters)
def command_time(user, command="", parameters=""):
"""Show the current world time in elapsed increments."""
- user.send(muffmisc.repr_long(muffmisc.getlong(muffvars.variable_data,
- "time", "elapsed")) + " increments elapsed since the world was created.")
+ user.send(muffuniv.universe.internals["counters"].get("elapsed") + " increments elapsed since the world was created.")
def command_help(user, command="", parameters=""):
"""List available commands and provide help for commands."""
if parameters:
# is the command word one for which we have data?
- if parameters in command_list:
+ if parameters in muffuniv.universe.commands.keys():
# add a description if provided
- try:
- description = command_data.get(parameters, "description")
- except:
+ description = muffuniv.universe.commands[parameters].get("description")
+ if not description:
description = "(no short description provided)"
- output = "$(grn)" + parameters + "$(nrm) - " + command_data.get(parameters, "description") + "$(eol)$(eol)"
+ output = "$(grn)" + parameters + "$(nrm) - " + description + "$(eol)$(eol)"
# add the help text if provided
- try:
- help_text = command_data.get(parameters, "help")
- except:
+ help_text = muffuniv.universe.commands[parameters].get("help")
+ if not help_text:
help_text = "No help is provided for this command."
output += help_text
# give a sorted list of commands with descriptions if provided
output = "These are the commands available to you:$(eol)$(eol)"
- sorted_commands = command_list
+ sorted_commands = muffuniv.universe.commands.keys()
sorted_commands.sort()
for item in sorted_commands:
- try:
- description = command_data.get(item, "description")
- except:
+ description = muffuniv.universe.commands[item].get("description")
+ if not description:
description = "(no short description provided)"
- output += " $(grn)" + item + "$(nrm) - " + command_data.get(item, "description") + "$(eol)"
+ output += " $(grn)" + item + "$(nrm) - " + description + "$(eol)"
output += "$(eol)Enter \"help COMMAND\" for help on a command named \"COMMAND\"."
# send the accumulated output to the user
else:
user.send("What do you want to say?")
+def command_show(user, command="", parameters=""):
+ """Show program data."""
+ if parameters == "avatars":
+ message = "These are the avatars managed by your account:$(eol)"
+ avatars = user.list_avatar_names()
+ avatars.sort()
+ for avatar in avatars: message += "$(eol) $(grn)" + avatar + "$(nrm)"
+ elif parameters == "files":
+ message = "These are the current files containing the universe:$(eol)"
+ keys = muffuniv.universe.files.keys()
+ keys.sort()
+ for key in keys: message += "$(eol) $(grn)" + key + "$(nrm)"
+ elif parameters == "universe":
+ message = "These are the current elements in the universe:$(eol)"
+ keys = muffuniv.universe.contents.keys()
+ keys.sort()
+ for key in keys: message += "$(eol) $(grn)" + key + "$(nrm)"
+ elif parameters: message = "I don't know what \"" + parameters + "\" is."
+ else: message = "What do you want to show?"
+ user.send(message)
+
def command_error(user, command="", parameters=""):
"""Generic error for an unrecognized command word."""