diff --git a/evennia/commands/cmdparser.py b/evennia/commands/cmdparser.py index 97ce52ce2a..c9924f2c49 100644 --- a/evennia/commands/cmdparser.py +++ b/evennia/commands/cmdparser.py @@ -66,7 +66,7 @@ def cmdparser(raw_string, cmdset, caller, match_index=None): return (cmdname, args, cmdobj, cmdlen, mratio) if not raw_string: - return None + return [] matches = [] diff --git a/evennia/commands/cmdsethandler.py b/evennia/commands/cmdsethandler.py index 918d08a79e..07b2f6c52b 100644 --- a/evennia/commands/cmdsethandler.py +++ b/evennia/commands/cmdsethandler.py @@ -119,7 +119,6 @@ def import_cmdset(path, cmdsetobj, emit_to_obj=None, no_logging=False): #print "importing %s: _CACHED_CMDSETS=%s" % (python_path, _CACHED_CMDSETS) wanted_cache_key = python_path cmdsetclass = _CACHED_CMDSETS.get(wanted_cache_key, None) - errstring = "" if not cmdsetclass: #print "cmdset '%s' not in cache. Reloading %s on %s." % (wanted_cache_key, python_path, cmdsetobj) # Not in cache. Reload from disk. @@ -130,21 +129,22 @@ def import_cmdset(path, cmdsetobj, emit_to_obj=None, no_logging=False): #instantiate the cmdset (and catch its errors) if callable(cmdsetclass): cmdsetclass = cmdsetclass(cmdsetobj) + errstring = "" return cmdsetclass except ImportError, e: - logger.log_trace() + #logger.log_trace() errstring += _("Error loading cmdset {path}: {error}") errstring = errstring.format(path=python_path, error=e) except KeyError: - logger.log_trace() + #logger.log_trace() errstring += _("Error in loading cmdset: No cmdset class '{classname}' in {path}.") errstring = errstring.format(classname=classname, path=python_path) except SyntaxError, e: - logger.log_trace() + #logger.log_trace() errstring += _("SyntaxError encountered when loading cmdset '{path}': {error}.") errstring = errstring.format(path=python_path, error=e) except Exception, e: - logger.log_trace() + #logger.log_trace() errstring += _("Compile/Run error when loading cmdset '{path}': {error}.") errstring = errstring.format(path=python_path, error=e) diff --git a/evennia/contrib/menu_login.py b/evennia/contrib/menu_login.py index d9dc29fa7b..1355345552 100644 --- a/evennia/contrib/menu_login.py +++ b/evennia/contrib/menu_login.py @@ -302,26 +302,21 @@ node1a = MenuNode("node1a", text="Please enter your account name (empty to abort links=["START", "node1b"], helptext=["Enter the account name you previously registered with."], keywords=[CMD_NOINPUT, CMD_NOMATCH], - selectcmds=[CmdBackToStart, CmdUsernameSelect], - nodefaultcmds=True) # if we don't, default help/look will be triggered by names starting with l/h ... + selectcmds=[CmdBackToStart, CmdUsernameSelect]) node1b = MenuNode("node1b", text="Please enter your password (empty to go back).", links=["node1a", "END"], keywords=[CMD_NOINPUT, CMD_NOMATCH], - selectcmds=[CmdPasswordSelectBack, CmdPasswordSelect], - nodefaultcmds=True) - + selectcmds=[CmdPasswordSelectBack, CmdPasswordSelect]) node2a = MenuNode("node2a", text="Please enter your desired account name (empty to abort).", links=["START", "node2b"], helptext="Account name can max be 30 characters or fewer. Letters, spaces, digits and @/./+/-/_ only.", keywords=[CMD_NOINPUT, CMD_NOMATCH], - selectcmds=[CmdBackToStart, CmdUsernameCreate], - nodefaultcmds=True) + selectcmds=[CmdBackToStart, CmdUsernameCreate]) node2b = MenuNode("node2b", text="Please enter your password (empty to go back).", links=["node2a", "START"], helptext="Try to pick a long and hard-to-guess password.", keywords=[CMD_NOINPUT, CMD_NOMATCH], - selectcmds=[CmdPasswordCreateBack, CmdPasswordCreate], - nodefaultcmds=True) + selectcmds=[CmdPasswordCreateBack, CmdPasswordCreate]) node3 = MenuNode("node3", text=LOGIN_SCREEN_HELP, links=["START"], helptext="", @@ -348,7 +343,7 @@ class CmdUnloggedinLook(Command): to the menu's own look command.. """ key = CMD_LOGINSTART - aliases = ["look", "l"] + # obs, this should NOT have aliases for look or l, this will clash with the menu version! locks = "cmd:all()" arg_regex = r"^$" diff --git a/evennia/settings_default.py b/evennia/settings_default.py index ad7a06ae56..4d15352390 100644 --- a/evennia/settings_default.py +++ b/evennia/settings_default.py @@ -295,7 +295,7 @@ CMDSET_CHARACTER = "commands.default_cmdsets.CharacterCmdSet" # Command set for players without a character (ooc) CMDSET_PLAYER = "commands.default_cmdsets.PlayerCmdSet" # Location to search for cmdsets if full path not given -CMDSET_PATHS = ["commands"] +CMDSET_PATHS = ["commands", "evennia", "contribs"] # Line editor path. Points to a line editor class that commands may use to give # users extended editing control. See the default path for a reference implementation @@ -313,7 +313,7 @@ SERVER_SESSION_CLASS = "evennia.server.serversession.ServerSession" # immediately entered path fail to find a typeclass. It allows for # shorter input strings. They must either base off the game directory # or start from the evennia library. -TYPECLASS_PATHS = ["typeclasses", "evennia.contrib", "evennia.contrib.tutorial_examples"] +TYPECLASS_PATHS = ["typeclasses", "evennia", "evennia.contrib", "evennia.contrib.tutorial_examples"] # Typeclass for player objects (linked to a character) (fallback) BASE_PLAYER_TYPECLASS = "typeclasses.players.Player"