Using poethepoet as a library¶
Normally poethepoet would be installed as a tool or poetry plugin, but it can also be used as a library to embed task runner capabilities into another tool.
The following script replicates the main functionality of the poe standalone cli.
import sys
from poethepoet.app import PoeThePoet
if __name__ == "__main__":
app = PoeThePoet()
result = app(cli_args=sys.argv[1:])
if result:
sys.exit(result)
The PoeThePoet class accepts various optional arguments to customize its behavior as described below.
- class poethepoet.app.PoeThePoet(cwd: ~pathlib.Path | str | None = None, config: ~collections.abc.Mapping[str, ~typing.Any] | PoeConfig | None = None, output: ~typing.IO = <_io.TextIOWrapper name='<stdout>' mode='w' encoding='utf-8'>, poetry_env_path: str | None = None, config_name: str | None = None, program_name: str = 'poe', env: ~collections.abc.Mapping[str, str] | None = None)¶
- Parameters:
cwd (Path, optional) – The directory that poe should take as the current working directory, this determines where to look for a pyproject.toml file, defaults to
Path().resolve()
config (dict | PoeConfig, optional) – Either a dictionary with the same schema as a pyproject.toml file, or a PoeConfig object to use as an alternative to loading config from a file.
output (IO, optional) – A stream for the application to write its own output to, defaults to sys.stdout
poetry_env_path (str, optional) – The path to the poetry virtualenv. If provided then it is used by the PoetryExecutor, instead of having to execute poetry in a subprocess to determine this.
config_name (str, optional) – The name of the file to load tasks and configuration from. If not set then poe will search for config by the following file names: pyproject.toml poe_tasks.toml poe_tasks.yaml poe_tasks.json
program_name (str, optional) – The name of the program that is being run. This is used primarily when outputting help messages, defaults to “poe”
env (dict, optional) – Optionally provide an alternative base environment for tasks to run with. If no mapping is provided then
os.environ
is used.