Split out a separate wad-only base class from WadMap. Load the wad-specific config when using it. Support overriding settings during fabricate.
This commit is contained in:
parent
057ac98843
commit
970e63e19b
3 changed files with 37 additions and 11 deletions
|
@ -22,7 +22,7 @@ class Base(Command):
|
||||||
parser.add_argument('--config-name', default='config.toml')
|
parser.add_argument('--config-name', default='config.toml')
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def run(self, parsed_args):
|
def init_base(self, parsed_args):
|
||||||
self._doom = pathlib.Path(parsed_args.doom)
|
self._doom = pathlib.Path(parsed_args.doom)
|
||||||
self._config_name = parsed_args.config_name
|
self._config_name = parsed_args.config_name
|
||||||
self._config = tomlkit.toml_file.TOMLFile(self.doom.joinpath(self.config_name)).read()
|
self._config = tomlkit.toml_file.TOMLFile(self.doom.joinpath(self.config_name)).read()
|
||||||
|
@ -32,8 +32,6 @@ class Base(Command):
|
||||||
for d in ("iwads", "pwads", "demos", "fabricate"):
|
for d in ("iwads", "pwads", "demos", "fabricate"):
|
||||||
self._init_path(d)
|
self._init_path(d)
|
||||||
|
|
||||||
self.take_action(parsed_args)
|
|
||||||
|
|
||||||
def _init_path(self, what):
|
def _init_path(self, what):
|
||||||
setattr(self, f"_{what}", self.doom.joinpath(self._config.get(what, what)))
|
setattr(self, f"_{what}", self.doom.joinpath(self._config.get(what, what)))
|
||||||
setattr(type(self), what, property(lambda self: getattr(self, f"_{what}")))
|
setattr(type(self), what, property(lambda self: getattr(self, f"_{what}")))
|
||||||
|
@ -52,7 +50,7 @@ class Base(Command):
|
||||||
|
|
||||||
def iwad_path(self, wad):
|
def iwad_path(self, wad):
|
||||||
iwad = self.iwads.joinpath(self._config.get("default_iwad"))
|
iwad = self.iwads.joinpath(self._config.get("default_iwad"))
|
||||||
iwadpath = self.pwads.joinpath("iwad")
|
iwadpath = self.pwads.joinpath(wad).joinpath("iwad")
|
||||||
if iwadpath.exists():
|
if iwadpath.exists():
|
||||||
with io.open(iwadpath) as f:
|
with io.open(iwadpath) as f:
|
||||||
iwad = self.iwads.joinpath(f.read().strip() + ".WAD")
|
iwad = self.iwads.joinpath(f.read().strip() + ".WAD")
|
||||||
|
|
|
@ -3,24 +3,46 @@ from cliff.command import Command
|
||||||
import dcc.config
|
import dcc.config
|
||||||
import io
|
import io
|
||||||
import os
|
import os
|
||||||
|
import tomlkit
|
||||||
|
|
||||||
class WadMap(dcc.config.Base):
|
class Wad(dcc.config.Base):
|
||||||
def get_parser(self, prog_name):
|
def get_parser(self, prog_name):
|
||||||
parser = super().get_parser(prog_name)
|
parser = super().get_parser(prog_name)
|
||||||
parser.add_argument('wad')
|
parser.add_argument('wad')
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def wad_init(self, parsed_args):
|
||||||
|
self.init_base(parsed_args)
|
||||||
|
self._wad = parsed_args.wad
|
||||||
|
wcp = self.pwads.joinpath(self.wad).joinpath(self.config_name)
|
||||||
|
if wcp.exists():
|
||||||
|
self._wad_config = tomlkit.toml_file.TOMLFile(wcp).read()
|
||||||
|
for k,v in self._wad_config.value.items():
|
||||||
|
print(k,v)
|
||||||
|
self._config.add(k,v)
|
||||||
|
|
||||||
|
def run(self, parsed_args):
|
||||||
|
self.wad_init(self, parsed_args)
|
||||||
|
self.take_action(parsed_args)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def wad(self):
|
||||||
|
return self._wad
|
||||||
|
|
||||||
|
|
||||||
|
class WadMap(Wad):
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super().get_parser(prog_name)
|
||||||
parser.add_argument('map')
|
parser.add_argument('map')
|
||||||
parser.add_argument('-n','--name','--demo_name')
|
parser.add_argument('-n','--name','--demo_name')
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def run(self, parsed_args):
|
def run(self, parsed_args):
|
||||||
self._wad = parsed_args.wad
|
|
||||||
self._map = parsed_args.map
|
self._map = parsed_args.map
|
||||||
self._name = parsed_args.name
|
self._name = parsed_args.name
|
||||||
super().run(parsed_args)
|
self.wad_init(parsed_args)
|
||||||
|
|
||||||
@property
|
self.take_action(parsed_args)
|
||||||
def wad(self):
|
|
||||||
return self._wad
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def map(self):
|
def map(self):
|
||||||
|
|
|
@ -17,6 +17,12 @@ class Fabricate(dcc.doom_base.WadMap):
|
||||||
command = [self.dsda]
|
command = [self.dsda]
|
||||||
if not parsed_args.fg and shutil.which("xvfb-run") is not None:
|
if not parsed_args.fg and shutil.which("xvfb-run") is not None:
|
||||||
command = ["xvfb-run"] + command
|
command = ["xvfb-run"] + command
|
||||||
subprocess.run(command + self.dsda_preamble() +
|
options = []
|
||||||
|
for k,v in self._config.get("fabricate_options", {}).items():
|
||||||
|
list.append(options, f"{k}={v}")
|
||||||
|
if len(options) > 0:
|
||||||
|
options = ["-assign", ",".join(options)]
|
||||||
|
print(options)
|
||||||
|
subprocess.run(command + self.dsda_preamble() + options +
|
||||||
["-timedemo", self.demo_in_path()] +
|
["-timedemo", self.demo_in_path()] +
|
||||||
["-viddump", self.video_path()])
|
["-viddump", self.video_path()])
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue