Tweaked namegen.py a bit

This commit is contained in:
Luke Rogers 2012-10-12 09:35:05 +13:00
parent 8d840723d4
commit 06f14ee59a

View file

@ -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'))