Source code for grass.experimental.create
"""Likely going into grass.grassdb.create"""
import pathlib
import tempfile
from grass.grassdb.checks import (
mapset_exists,
is_mapset_valid,
get_mapset_invalid_reason,
)
from grass.grassdb.create import (
create_mapset,
_directory_to_mapset,
)
from grass.grassdb.manage import delete_mapset, resolve_mapset_path, MapsetPath
[docs]def require_create_ensure_mapset(
path, location=None, mapset=None, *, create=False, overwrite=False, ensure=False
):
"""Checks that mapsets exists or creates it in a specified location
By default, it checks that the mapset exists and raises a ValueError otherwise.
If *create* is True and the mapset does not exists, it creates it.
If it exists and *overwrite* is True, it deletes the existing mapset
(with all the data in it). If *ensure* is True, existing mapset is used
as is and when there is none, a new mapset is created.
Where the mapset is specified by a full path or by location name and path
to the directory where the location is.
The path argument is positional-only. Location and mapset are recommend to be used
as positional.
"""
path = resolve_mapset_path(
path,
location,
mapset,
)
exists = mapset_exists(path)
if create and exists:
if not overwrite:
msg = (
f"Mapset '{path.mapset}' already exists, "
"use a different name, overwrite, or ensure"
)
raise ValueError(msg)
delete_mapset(path.directory, path.location, path.mapset)
if create or (ensure and not exists):
create_mapset(path.directory, path.location, path.mapset)
elif not exists or not is_mapset_valid(path):
reason = get_mapset_invalid_reason(path.directory, path.location, path.mapset)
msg = f"Mapset {path.mapset} is not valid: {reason}"
raise ValueError(msg)
[docs]def create_temporary_mapset(path, location=None) -> MapsetPath:
"""Create temporary mapset
The user of this function is responsible for deleting the contents of the
temporary directory and the directory itself when done with it.
"""
path = pathlib.Path(path)
if location:
path /= location
tmp_dir = tempfile.mkdtemp(dir=path)
new_path = resolve_mapset_path(tmp_dir)
_directory_to_mapset(new_path)
return new_path