Tweaked namegen.py a bit
This commit is contained in:
parent
8d840723d4
commit
06f14ee59a
1 changed files with 16 additions and 11 deletions
|
@ -6,11 +6,13 @@ import json, random, re, os
|
|||
TEMPLATE_RE = re.compile(r"\{(.+?)\}")
|
||||
GEN_DIR = "./plugins/data/name_files/"
|
||||
|
||||
|
||||
def get_generator(_json):
|
||||
data = json.loads(_json)
|
||||
return NameGenerator(data["name"], data["templates"],
|
||||
data["default_templates"], data["parts"])
|
||||
|
||||
|
||||
class NameGenerator(object):
|
||||
def __init__(self, name, templates, default_templates, parts):
|
||||
self.name = name
|
||||
|
@ -36,14 +38,12 @@ class NameGenerator(object):
|
|||
|
||||
return name
|
||||
|
||||
|
||||
def generate_names(self, amount, template=None):
|
||||
names = []
|
||||
for i in xrange(amount):
|
||||
names.append(self.generate_name())
|
||||
return names
|
||||
|
||||
|
||||
def get_template(self, template):
|
||||
return self.templates[template]
|
||||
|
||||
|
@ -53,27 +53,29 @@ def namegen(inp, notice=None):
|
|||
"namegen [generator] -- Generates some names using the chosen generator. " \
|
||||
"'namegen list' will display a list of all generators."
|
||||
|
||||
# clean and split up the input
|
||||
args = inp.strip().lower().split()
|
||||
# clean up the input
|
||||
inp = inp.strip().lower()
|
||||
|
||||
# get a list of available name generators
|
||||
files = os.listdir(GEN_DIR)
|
||||
all_modules = []
|
||||
for i in files:
|
||||
if os.path.splitext(i)[1] == ".json":
|
||||
all_modules.append(os.path.splitext(i)[0])
|
||||
all_modules.sort()
|
||||
|
||||
# command to return a list of all available generators
|
||||
if args[0] == "list":
|
||||
if inp == "list":
|
||||
message = "Available generators: "
|
||||
message += get_text_list(all_modules, 'and')
|
||||
notice(message)
|
||||
return
|
||||
|
||||
if inp:
|
||||
selected_module = args[0]
|
||||
selected_module = inp.split()[0]
|
||||
else:
|
||||
# make some generic fantasy names
|
||||
selected_module = ["fantasy"]
|
||||
selected_module = "fantasy"
|
||||
|
||||
# check if the selected module is valid
|
||||
if not selected_module in all_modules:
|
||||
|
@ -81,10 +83,13 @@ def namegen(inp, notice=None):
|
|||
|
||||
# load the name generator
|
||||
with open(os.path.join(GEN_DIR, "{}.json".format(selected_module))) as f:
|
||||
try:
|
||||
generator = get_generator(f.read())
|
||||
except ValueError as error:
|
||||
return "Unable to read name file: {}".format(error)
|
||||
|
||||
# time to generate some names
|
||||
name_list = generator.generate_names(10)
|
||||
|
||||
# and finally return the final message :D
|
||||
return "Some names to ponder: %s." % get_text_list(name_list, 'and')
|
||||
return "Some names to ponder: {}.".format(get_text_list(name_list, 'and'))
|
||||
|
|
Reference in a new issue