grass.grassdb package¶
Submodules¶
grass.grassdb.checks module¶
Checking objects in a GRASS GIS Spatial Database
(C) 2020 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
-
grass.grassdb.checks.
can_start_in_mapset
(mapset_path, ignore_lock: bool = False) → bool[source]¶ Check if a mapset from a gisrc file is usable for new session
-
grass.grassdb.checks.
dir_contains_location
(path: str | os.PathLike[str]) → bool[source]¶ Return True if directory path contains a valid location
-
grass.grassdb.checks.
get_list_of_locations
(dbase)[source]¶ Get list of GRASS locations in given dbase
- Parameters
dbase – GRASS database path
- Returns
list of locations (sorted)
-
grass.grassdb.checks.
get_location_invalid_reason
(database, location, none_for_no_reason=False) → str | None[source]¶ Returns a message describing what is wrong with the Location
The goal is to provide the most suitable error message (rather than to do a quick check).
By default, when no reason is found, a message about unknown reason is returned. This applies also to the case when this function is called on a valid location (e.g. as a part of larger investigation).
none_for_no_reason=True
allows the function to be used as part of other diagnostic. When this function fails to find reason for invalidity, other the caller can continue the investigation in their context.- Parameters
database – Path to GRASS GIS database directory
location – name of a Location
none_for_no_reason – When True, return None when reason is unknown
- Returns
translated message or None
-
grass.grassdb.checks.
get_location_invalid_suggestion
(database, location) → str | None[source]¶ Return suggestion what to do when specified location is not valid
- It gives suggestion when:
A mapset was specified instead of a location.
A GRASS database was specified instead of a location.
-
grass.grassdb.checks.
get_location_name_invalid_reason
(grassdb, location_name)[source]¶ Get reasons why location name is not valid.
- It gets reasons when:
Name is not valid.
Location in the same path already exists.
Returns message as string if there was a reason, otherwise None.
-
grass.grassdb.checks.
get_lockfile_if_present
(database, location, mapset) → str | None[source]¶ Return path to lock if present, None otherwise
Returns the path as a string or None if nothing was found, so the return value can be used to test if the lock is present.
-
grass.grassdb.checks.
get_mapset_invalid_reason
(database, location, mapset, none_for_no_reason=False)[source]¶ Returns a message describing what is wrong with the Mapset
The goal is to provide the most suitable error message (rather than to do a quick check).
- Parameters
database – Path to GRASS GIS database directory
location – name of a Location
mapset – name of a Mapset
- Returns
translated message
-
grass.grassdb.checks.
get_mapset_lock_info
(mapset_path: str | os.PathLike[str])[source]¶ Get information about .gislock file. Assumes lock file exists, use is_mapset_locked to find out. Returns information as a dictionary with keys ‘owner’ (None if unknown), ‘lockpath’, and ‘timestamp’.
-
grass.grassdb.checks.
get_mapset_name_invalid_reason
(database, location, mapset_name)[source]¶ Get reasons why mapset name is not valid.
- It gets reasons when:
Name is not valid.
Name is reserved for OGR layers.
Mapset in the same path already exists.
Returns message as string if there was a reason, otherwise None.
-
grass.grassdb.checks.
get_mapset_owner
(mapset_path: str | os.PathLike[str]) → str | None[source]¶ Returns mapset owner name or None if owner name unknown. On Windows it always returns None.
-
grass.grassdb.checks.
get_reason_id_mapset_not_usable
(mapset_path)[source]¶ It finds a reason why mapset is not usable.
Returns a reason id as a string. If mapset path is None or no reason found, returns None.
-
grass.grassdb.checks.
get_reason_mapset_not_removable
(grassdb, location, mapset, check_permanent)[source]¶ Get reason why one mapset cannot be removed.
Parameter check_permanent is True of False. It depends on whether we want to check for permanent mapset or not.
Returns message as string if there was failed check, otherwise None.
-
grass.grassdb.checks.
get_reasons_grassdb_not_removable
(grassdb)[source]¶ Get reasons why one grassdb cannot be removed.
Returns messages as list if there were any failed checks, otherwise empty list.
-
grass.grassdb.checks.
get_reasons_location_not_removable
(grassdb, location)[source]¶ Get reasons why one location cannot be removed.
Returns messages as list if there were any failed checks, otherwise empty list.
-
grass.grassdb.checks.
get_reasons_locations_not_removable
(locations)[source]¶ Get reasons why locations cannot be removed.
Parameter locations is a list of tuples (database, location).
Returns messages as list if there were any failed checks, otherwise empty list.
-
grass.grassdb.checks.
get_reasons_mapsets_not_removable
(mapsets, check_permanent)[source]¶ Get reasons why mapsets cannot be removed.
Parameter mapsets is a list of tuples (database, location, mapset). Parameter check_permanent is True of False. It depends on whether we want to check for permanent mapset or not.
Returns messages as list if there were any failed checks, otherwise empty list.
-
grass.grassdb.checks.
is_current_user_mapset_owner
(mapset_path: str | os.PathLike[str]) → bool[source]¶ Returns True if mapset owner is the current user. On Windows it always returns True.
-
grass.grassdb.checks.
is_different_mapset_owner
(mapset_path: str | os.PathLike[str]) → bool[source]¶ Returns True if mapset owner is different from the current user
-
grass.grassdb.checks.
is_fallback_session
()[source]¶ Checks if a user encounters a fallback GRASS session.
Returns True if a user encounters a fallback session. It occurs when a last mapset is not usable and at the same time a user is in a temporary location.
-
grass.grassdb.checks.
is_first_time_user
()[source]¶ Check if a user is a first-time user.
Returns True if a user is a first-time user. It occurs when a gisrc file has initial settings either in last used mapset or in current mapset settings.
-
grass.grassdb.checks.
is_location_current
(database, location) → bool[source]¶ Return True if the given GRASS Location is the current location
-
grass.grassdb.checks.
is_location_name_valid
(database, location_name)[source]¶ Check if location name is valid.
Returns True if location name is valid, otherwise False.
-
grass.grassdb.checks.
is_location_valid
(path: str | os.PathLike[str], location=None) → bool[source]¶ Return True if GRASS Location is valid
- Parameters
path – Path to a Location or to a GRASS GIS database directory
location – name of a Location if not part of path
-
grass.grassdb.checks.
is_mapset_current
(database, location, mapset) → bool[source]¶ Return True if the given GRASS Mapset is the current mapset
-
grass.grassdb.checks.
is_mapset_locked
(mapset_path: str | os.PathLike[str]) → bool[source]¶ Check if the mapset is locked
-
grass.grassdb.checks.
is_mapset_name_valid
(database, location, mapset_name)[source]¶ Check if mapset name is valid.
Returns True if mapset name is valid, otherwise False.
-
grass.grassdb.checks.
is_mapset_valid
(path: str | os.PathLike[str], location=None, mapset=None) → bool[source]¶ Return True if GRASS Mapset is valid
Either only path is provided or all three parameters need to be provided.
- Parameters
path – Path to a Mapset or to a GRASS GIS database directory
location – name of a Location if not part of path
mapset – name of a Mapset if not part of path
-
grass.grassdb.checks.
location_exists
(path: str | os.PathLike[str], location=None) → bool[source]¶ Returns True whether location path exists.
- Parameters
path – Path to a Location or to a GRASS GIS database directory
location – name of a Location if not part of path
-
grass.grassdb.checks.
mapset_exists
(path: str | os.PathLike[str], location=None, mapset=None) → bool[source]¶ Returns True whether mapset path exists.
Either only path is provided or all three parameters need to be provided.
- Parameters
path – Path to a Mapset or to a GRASS GIS database directory
location – name of a Location if not part of path
mapset – name of a Mapset if not part of path
grass.grassdb.config module¶
Set global variables for objects in a GRASS GIS Spatial Database
(C) 2020 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
grass.grassdb.create module¶
Create objects in GRASS GIS Spatial Database
(C) 2020 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
grass.grassdb.data module¶
Manipulate data in mapsets in GRASS GIS Spatial Database
(C) 2020 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
-
grass.grassdb.data.
map_exists
(name, element, mapset=None, env=None) → bool[source]¶ Check is map is present in the mapset given in the environment
- Parameters
name – Name of the map
element – Data type (‘raster’, ‘raster_3d’, and ‘vector’)
env – Environment created by function grass.script.create_environment
mapset – Mapset name, “.” for current mapset only, None for all mapsets in the search path
grass.grassdb.history module¶
Managing existing history files included within mapset
(C) 2023 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
-
class
grass.grassdb.history.
Status
(value)[source]¶ Bases:
enum.Enum
Enum representing a set of status constants that are used to represent various states or command outcomes.
-
ABORTED
= 'aborted'¶
-
FAILED
= 'failed'¶
-
RUNNING
= 'running'¶
-
SUCCESS
= 'success'¶
-
UNKNOWN
= 'unknown'¶
-
-
grass.grassdb.history.
add_entry
(history_path, entry)[source]¶ Add entry to history file.
- Parameters
history_path (str) – path to the history log file
entry (dict) – entry consisting of ‘command’ and ‘command_info’ keys
-
grass.grassdb.history.
convert_plain_text_to_JSON
(history_path)[source]¶ Convert plain text history log to JSON format.
- Parameters
history_path (str) – path to the history log file
-
grass.grassdb.history.
copy
(history_path, target_path)[source]¶ Copy history file to the target location.
- Parameters
history_path (str) – path to the history log file
target_path (str) – target location for history log file
- Return boolean
True if file is successfully copied
-
grass.grassdb.history.
ensure_history_file
(history_path)[source]¶ Set up a new GUI history file if it doesn’t exist.
- Parameters
history_path (str) – path to the history file
-
grass.grassdb.history.
filter
(json_data, command, timestamp)[source]¶ Filter JSON history file based on provided command and the time of command launch.
- Parameters
json_data – List of dictionaries representing JSON entries
command – First filtering argument representing command as string
timestamp – Second filtering argument representing the time of command launch
- Returns
Index of entry matching the filter criteria.
-
grass.grassdb.history.
get_current_mapset_gui_history_path
()[source]¶ Return path to the current mapset history file. This function does not ensure that the file exists.
-
grass.grassdb.history.
get_history_file_extension
(history_path)[source]¶ Get extension of the history file. The standard long-term format is plain text. Newly it is stored as JSON-formatted.
- Parameters
history_path (str) – path to the history log file
- Return str extension
None (plain text) or .json
-
grass.grassdb.history.
get_initial_command_info
(env_run)[source]¶ Get information about the launched command.
- Parameters
env_run – environment needed for processing grass command
- Return cmd_info dict
initial information about the launched command
-
grass.grassdb.history.
read
(history_path)[source]¶ Read the content of the history file.
- Parameters
history_path (str) – path to the history log file
- Return content_list
list of dictionaries
with ‘command’ and ‘command_info’ keys
-
grass.grassdb.history.
remove_entry
(history_path, index: int)[source]¶ Remove entry from history file.
- Parameters
history_path (str) – path to the history log file
index (int) – index of the command to be removed
-
grass.grassdb.history.
update_entry
(history_path, command_info, index=None)[source]¶ Update entry in history file. If index is None it updates a last entry.
- Parameters
history_path (str) – path to the history log file
command_info (dict) – command info entry for update
index (int|None) – index of the command to be updated
grass.grassdb.manage module¶
Managing existing objects in a GRASS GIS Spatial Database
(C) 2020 by the GRASS Development Team This program is free software under the GNU General Public License (>=v2). Read the file COPYING that comes with GRASS for details.
-
class
grass.grassdb.manage.
MapsetPath
(path, directory, location, mapset)[source]¶ Bases:
object
This is a representation of a path to mapset.
Individual components are accessible through read-only properties and objects have an os.PathLike interface.
Paths are currently stored as is (not resolved, not expanded), but that may change in the future.
-
property
directory
¶ Location name
-
property
location
¶ Location name
-
property
mapset
¶ Mapset name
-
property
path
¶ Full path to the mapset as a pathlib.Path object
-
property
-
grass.grassdb.manage.
rename_location
(database, old_name, new_name)[source]¶ Rename location from old_name to new_name
-
grass.grassdb.manage.
rename_mapset
(database, location, old_name, new_name)[source]¶ Rename mapset from old_name to new_name
-
grass.grassdb.manage.
resolve_mapset_path
(path, location=None, mapset=None) → grass.grassdb.manage.MapsetPath[source]¶ Resolve full path to mapset from given combination of parameters.
Full or relative path to mapset can be provided as path. If the path points to a valid location instead of a valid mapset, the mapset defaults to PERMANENT.
Alternatively, location and mapset can be provided separately. In that case, location and mapset are added to the path. If location is provided and mapset is not, mapset defaults to PERMANENT.
Home represented by
~
(tilde) and relative paths are resolved and the result contains absolute paths.The function does not enforce the existence of the directory or that it is a mapset. It only manipulates the paths except for internal checks which help to determine the result in some cases. On Windows, if the path does not exist and
..
is present in the path, it will be not be resolved due to path resolution limitation in the Python pathlib package.Returns a MapsetPath object.