2014-11-02 02:09:58 +01:00
|
|
|
import sys
|
|
|
|
import argparse
|
2016-08-29 20:04:35 +02:00
|
|
|
from .entrypoints_utils import get_one_entrypoint
|
2014-11-02 02:09:58 +01:00
|
|
|
import json
|
2021-03-27 12:29:20 +01:00
|
|
|
from logging import getLogger, basicConfig
|
2019-06-25 13:49:33 +02:00
|
|
|
|
|
|
|
log = getLogger("audiogen")
|
2014-11-02 02:09:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
def get_audiogenerator(kind):
|
2019-06-25 13:49:33 +02:00
|
|
|
"""Messes with entrypoints to return an audiogenerator function"""
|
|
|
|
return get_one_entrypoint("larigira.audiogenerators", kind)
|
2014-11-02 02:09:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
def get_parser():
|
2019-06-25 13:49:33 +02:00
|
|
|
parser = argparse.ArgumentParser(description="Generate audio and output paths")
|
2021-03-27 12:29:20 +01:00
|
|
|
parser.add_argument("--log-level", choices=['DEBUG', 'INFO', 'WARNING', 'DEBUG'], default='WARNING')
|
2019-06-25 13:49:33 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"audiospec",
|
|
|
|
metavar="AUDIOSPEC",
|
|
|
|
type=str,
|
|
|
|
nargs=1,
|
|
|
|
help="filename for audiospec, formatted in json",
|
|
|
|
)
|
2014-11-02 02:09:58 +01:00
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def read_spec(fname):
|
2016-07-19 17:11:36 +02:00
|
|
|
try:
|
2019-06-25 13:49:33 +02:00
|
|
|
if fname == "-":
|
2016-07-19 17:11:36 +02:00
|
|
|
return json.load(sys.stdin)
|
|
|
|
with open(fname) as buf:
|
|
|
|
return json.load(buf)
|
|
|
|
except ValueError:
|
|
|
|
sys.stderr.write("Error: invalid JSON\n")
|
|
|
|
sys.exit(1)
|
2014-11-02 02:09:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
def check_spec(spec):
|
2019-06-25 13:49:33 +02:00
|
|
|
if "kind" not in spec:
|
2014-11-02 02:09:58 +01:00
|
|
|
yield "Missing field 'kind'"
|
|
|
|
|
|
|
|
|
2014-11-03 02:15:22 +01:00
|
|
|
def audiogenerate(spec):
|
2019-06-25 13:49:33 +02:00
|
|
|
gen = get_audiogenerator(spec["kind"])
|
2014-11-02 02:09:58 +01:00
|
|
|
return tuple(gen(spec))
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2019-06-25 13:49:33 +02:00
|
|
|
"""Main function for the "larigira-audiogen" executable"""
|
2014-11-02 02:09:58 +01:00
|
|
|
args = get_parser().parse_args()
|
2021-03-27 12:29:20 +01:00
|
|
|
basicConfig(level=args.log_level)
|
2014-11-02 02:09:58 +01:00
|
|
|
spec = read_spec(args.audiospec[0])
|
|
|
|
errors = tuple(check_spec(spec))
|
|
|
|
if errors:
|
2015-02-01 19:57:50 +01:00
|
|
|
log.error("Errors in audiospec")
|
2014-11-02 02:09:58 +01:00
|
|
|
for err in errors:
|
2019-06-25 13:49:33 +02:00
|
|
|
sys.stderr.write("Error: {}\n".format(err))
|
2014-11-02 02:09:58 +01:00
|
|
|
sys.exit(1)
|
2014-11-03 02:15:22 +01:00
|
|
|
for path in audiogenerate(spec):
|
2014-11-02 02:09:58 +01:00
|
|
|
print(path)
|
|
|
|
|
|
|
|
|
2019-06-25 13:49:33 +02:00
|
|
|
if __name__ == "__main__":
|
2014-11-02 02:09:58 +01:00
|
|
|
main()
|