add jobs
This commit is contained in:
parent
96800e349f
commit
0d2662a2b6
129
deadsands/site_tools/jobs.py
Normal file
129
deadsands/site_tools/jobs.py
Normal file
|
@ -0,0 +1,129 @@
|
||||||
|
import random
|
||||||
|
import collections
|
||||||
|
|
||||||
|
from npc.generator.base import generate_npc
|
||||||
|
|
||||||
|
|
||||||
|
Crime = collections.namedtuple('Crime', ['name', 'min_bounty', 'max_bounty'])
|
||||||
|
|
||||||
|
|
||||||
|
class BaseJob:
|
||||||
|
"""
|
||||||
|
The base class for random odd jobs.
|
||||||
|
"""
|
||||||
|
def __init__(
|
||||||
|
self,
|
||||||
|
name=None,
|
||||||
|
details=None,
|
||||||
|
reward=None,
|
||||||
|
contact=None,
|
||||||
|
location=None
|
||||||
|
):
|
||||||
|
self._name = name
|
||||||
|
self._details = details
|
||||||
|
self._reward = reward
|
||||||
|
self._contact = contact
|
||||||
|
self._location = location
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
return self._name
|
||||||
|
|
||||||
|
@property
|
||||||
|
def details(self):
|
||||||
|
if not self._details:
|
||||||
|
self._details = (
|
||||||
|
f"Speak to {self.contact} in {self.location}. "
|
||||||
|
)
|
||||||
|
return self._details
|
||||||
|
|
||||||
|
@property
|
||||||
|
def reward(self):
|
||||||
|
return self._reward
|
||||||
|
|
||||||
|
@property
|
||||||
|
def contact(self):
|
||||||
|
return self._contact
|
||||||
|
|
||||||
|
@property
|
||||||
|
def location(self):
|
||||||
|
return self._location
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return f"{self.__class__.__name__}: {self.name}\n{self.details}"
|
||||||
|
|
||||||
|
|
||||||
|
class Bounty(BaseJob):
|
||||||
|
"""
|
||||||
|
A Bounty job.
|
||||||
|
"""
|
||||||
|
|
||||||
|
crimes = [
|
||||||
|
Crime(name='theft', min_bounty=50, max_bounty=500),
|
||||||
|
Crime(name='overdue faction fees', min_bounty=50, max_bounty=500),
|
||||||
|
Crime(name='unpaid bar tab', min_bounty=50, max_bounty=100),
|
||||||
|
Crime(name="unpaid debt", min_bounty=50, max_bounty=200),
|
||||||
|
Crime(name='cattle rustling', min_bounty=200, max_bounty=1000),
|
||||||
|
Crime(name='murder', min_bounty=500, max_bounty=2000),
|
||||||
|
Crime(name='kidnapping', min_bounty=500, max_bounty=2000)
|
||||||
|
]
|
||||||
|
|
||||||
|
def __init__(self, target=None, crime=None, dead=None, alive=None, **kwargs):
|
||||||
|
super().__init__(**kwargs)
|
||||||
|
|
||||||
|
self._target = target
|
||||||
|
|
||||||
|
self._crime = crime
|
||||||
|
|
||||||
|
dead_or_alive = []
|
||||||
|
if dead is None:
|
||||||
|
dead = random.choice([True, False])
|
||||||
|
if alive is None:
|
||||||
|
alive = True
|
||||||
|
if dead:
|
||||||
|
dead_or_alive.append('Dead')
|
||||||
|
if alive:
|
||||||
|
dead_or_alive.append('Alive')
|
||||||
|
self._dead_or_alive = ' or '.join(dead_or_alive)
|
||||||
|
|
||||||
|
if not self._reward:
|
||||||
|
# need to round to the nearest 10 < 100, nearest 100 otherwise
|
||||||
|
reward = round(random.randint(self.crime.min_bounty, self.crime.max_bounty), 5)
|
||||||
|
self._reward = f"{reward} Gold Pieces"
|
||||||
|
|
||||||
|
if not self._name:
|
||||||
|
self._name = (
|
||||||
|
f"{self.reward} for the capture of {self.target.full_name.upper()}, "
|
||||||
|
f"wanted for the crime of {self.crime.name.upper()}. "
|
||||||
|
f"Wanted {self._dead_or_alive.upper()}"
|
||||||
|
)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def crime(self):
|
||||||
|
if not self._crime:
|
||||||
|
self._crime = random.choice(Bounty.crimes)
|
||||||
|
return self._crime
|
||||||
|
|
||||||
|
@property
|
||||||
|
def details(self):
|
||||||
|
if not self._details:
|
||||||
|
self._details = f"{self.target.description}\nWhereabouts {self.target.whereabouts}."
|
||||||
|
return self._details
|
||||||
|
|
||||||
|
@property
|
||||||
|
def target(self):
|
||||||
|
if not self._target:
|
||||||
|
self._target = generate_npc()
|
||||||
|
return self._target
|
||||||
|
|
||||||
|
|
||||||
|
classes = BaseJob.__subclasses__()
|
||||||
|
job_types = [c.__name__ for c in classes]
|
||||||
|
|
||||||
|
|
||||||
|
def generate_job():
|
||||||
|
return random.choice(classes)()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
print(Bounty())
|
|
@ -8,6 +8,7 @@ from rolltable.tables import RollTable
|
||||||
|
|
||||||
from site_tools.shell.base import BasePrompt, command
|
from site_tools.shell.base import BasePrompt, command
|
||||||
from site_tools import campaign
|
from site_tools import campaign
|
||||||
|
from site_tools import jobs
|
||||||
|
|
||||||
from npc.generator.base import generate_npc
|
from npc.generator.base import generate_npc
|
||||||
from reckoning.calendar import TelisaranCalendar
|
from reckoning.calendar import TelisaranCalendar
|
||||||
|
@ -43,6 +44,7 @@ class DMShell(BasePrompt):
|
||||||
("", " [F3] Trinkets"),
|
("", " [F3] Trinkets"),
|
||||||
("", " [F4] NPC"),
|
("", " [F4] NPC"),
|
||||||
("", " [F5] Date"),
|
("", " [F5] Date"),
|
||||||
|
("", " [F6] Job"),
|
||||||
("", " [F8] Save"),
|
("", " [F8] Save"),
|
||||||
("", " [^Q] Quit "),
|
("", " [^Q] Quit "),
|
||||||
]
|
]
|
||||||
|
@ -74,6 +76,10 @@ class DMShell(BasePrompt):
|
||||||
def date(event):
|
def date(event):
|
||||||
self.date()
|
self.date()
|
||||||
|
|
||||||
|
@self.key_bindings.add("f6")
|
||||||
|
def job(event):
|
||||||
|
self.job()
|
||||||
|
|
||||||
@self.key_bindings.add("f8")
|
@self.key_bindings.add("f8")
|
||||||
def save(event):
|
def save(event):
|
||||||
self.save()
|
self.save()
|
||||||
|
@ -358,3 +364,17 @@ class DMShell(BasePrompt):
|
||||||
self.console.error(f"Invalid level: {newlevel}. Levels must be between 1 and 20.")
|
self.console.error(f"Invalid level: {newlevel}. Levels must be between 1 and 20.")
|
||||||
self._campaign['level'] = newlevel
|
self._campaign['level'] = newlevel
|
||||||
self.console.print(f"Party is currently at level {self._campaign['level']}.")
|
self.console.print(f"Party is currently at level {self._campaign['level']}.")
|
||||||
|
|
||||||
|
@command(usage="""
|
||||||
|
[title]JOB[/title]
|
||||||
|
|
||||||
|
Generate a random job.
|
||||||
|
|
||||||
|
[title]USAGE[/title]
|
||||||
|
|
||||||
|
[link]> job[/link]
|
||||||
|
|
||||||
|
""")
|
||||||
|
def job(self, parts=[]):
|
||||||
|
self.console.print(jobs.generate_job())
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user