2023-12-04 22:28:03 -08:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
|
2023-12-26 18:41:43 -08:00
|
|
|
from enum import Enum
|
2023-12-19 23:52:09 -08:00
|
|
|
from pathlib import Path
|
|
|
|
|
2023-12-04 22:28:03 -08:00
|
|
|
import typer
|
|
|
|
|
2023-12-26 18:41:43 -08:00
|
|
|
from rich import print
|
2023-12-04 22:28:03 -08:00
|
|
|
from rich.logging import RichHandler
|
|
|
|
from rich.console import Console
|
2023-12-26 18:41:43 -08:00
|
|
|
from rich.table import Table
|
2023-12-04 22:28:03 -08:00
|
|
|
|
2023-12-26 18:41:43 -08:00
|
|
|
from dnd_item.types import WeaponGenerator, MagicWeaponGenerator, RollTable
|
2023-12-19 23:52:09 -08:00
|
|
|
from dnd_item import five_e
|
2023-12-04 22:28:03 -08:00
|
|
|
|
|
|
|
app = typer.Typer()
|
2023-12-19 23:52:09 -08:00
|
|
|
app_state = {}
|
2023-12-04 22:28:03 -08:00
|
|
|
|
|
|
|
|
2023-12-26 18:41:43 -08:00
|
|
|
class OUTPUT_FORMATS(Enum):
|
|
|
|
text = 'text'
|
|
|
|
yaml = 'yaml'
|
|
|
|
markdown = 'markdown'
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-12-04 22:28:03 -08:00
|
|
|
@app.callback()
|
2023-12-24 12:24:33 -08:00
|
|
|
def main(
|
|
|
|
cr: int = typer.Option(default=None, help='The Challenge Rating to use when determining rarity.'),
|
|
|
|
):
|
2023-12-04 22:28:03 -08:00
|
|
|
debug = os.getenv("FANITEM_DEBUG", None)
|
|
|
|
logging.basicConfig(
|
|
|
|
format="%(name)s %(message)s",
|
|
|
|
level=logging.DEBUG if debug else logging.INFO,
|
|
|
|
handlers=[RichHandler(rich_tracebacks=True, tracebacks_suppress=[typer])],
|
|
|
|
)
|
|
|
|
logging.getLogger('markdown_it').setLevel(logging.ERROR)
|
|
|
|
|
2023-12-24 12:24:33 -08:00
|
|
|
app_state['cr'] = cr or 0
|
2023-12-19 23:52:09 -08:00
|
|
|
app_state['data'] = Path(__file__).parent / Path("sources")
|
|
|
|
|
2023-12-04 22:28:03 -08:00
|
|
|
|
|
|
|
@app.command()
|
2023-12-23 16:41:21 -08:00
|
|
|
def weapon(count: int = typer.Option(1, help="The number of weapons to generate.")):
|
2023-12-19 23:52:09 -08:00
|
|
|
console = Console()
|
2023-12-24 12:24:33 -08:00
|
|
|
for weapon in WeaponGenerator().random(count=count, challenge_rating=app_state['cr']):
|
2023-12-23 16:41:21 -08:00
|
|
|
console.print(weapon.details)
|
|
|
|
|
|
|
|
|
|
|
|
@app.command()
|
|
|
|
def magic_weapon(count: int = typer.Option(1, help="The number of weapons to generate.")):
|
|
|
|
console = Console()
|
2023-12-24 12:24:33 -08:00
|
|
|
for weapon in MagicWeaponGenerator().random(count=count, challenge_rating=app_state['cr']):
|
2023-12-23 16:41:21 -08:00
|
|
|
console.print(weapon.details)
|
2023-12-19 23:52:09 -08:00
|
|
|
|
2023-12-26 18:41:43 -08:00
|
|
|
@app.command("roll-table")
|
|
|
|
def table(
|
|
|
|
die: int = typer.Option(
|
|
|
|
20,
|
|
|
|
help='The size of the die for which to create a table'),
|
|
|
|
hide_rolls: bool = typer.Option(
|
|
|
|
False,
|
|
|
|
help='If True, do not show the Roll column.',
|
|
|
|
),
|
|
|
|
collapsed: bool = typer.Option(
|
|
|
|
True,
|
|
|
|
help='If True, collapse multiple die values with the same option.'),
|
|
|
|
width: int = typer.Option(
|
|
|
|
120,
|
|
|
|
help='Width of the table.'),
|
|
|
|
output: OUTPUT_FORMATS = typer.Option(
|
|
|
|
'text',
|
|
|
|
help='The output format to use.',
|
|
|
|
)
|
|
|
|
):
|
|
|
|
"""
|
|
|
|
CLI for creating roll tables of randomly-generated items.
|
|
|
|
"""
|
|
|
|
rt = RollTable(
|
|
|
|
sources=[MagicWeaponGenerator],
|
|
|
|
die=die,
|
|
|
|
hide_rolls=hide_rolls,
|
|
|
|
challenge_rating=app_state['cr'],
|
|
|
|
)
|
|
|
|
|
|
|
|
if output == OUTPUT_FORMATS.yaml:
|
|
|
|
print(rt.as_yaml())
|
|
|
|
elif output == OUTPUT_FORMATS.markdown:
|
|
|
|
print(rt.as_markdown)
|
|
|
|
else:
|
|
|
|
rows = rt.rows if collapsed else rt.expanded_rows
|
|
|
|
table = Table(*rows[0], width=width)
|
|
|
|
for row in rows[1:]:
|
|
|
|
table.add_row(*row)
|
|
|
|
print(table)
|
|
|
|
|
|
|
|
|
2023-12-19 23:52:09 -08:00
|
|
|
|
|
|
|
@app.command()
|
|
|
|
def convert():
|
|
|
|
src = five_e.weapons()
|
|
|
|
print(src.as_yaml)
|