Note: A new GRASS GIS stable version has been released: GRASS GIS 7. Go directly to the new manual page here
NAME
grass64 - The GRASS startup program
SYNOPSIS
grass64 [-] [-v] [-h | -help | --help]
[-text | -gui | -tcltk | -oldtcltk | -wxpython | -wx]]
[[[GISDBASE/]LOCATION_NAME/]
MAPSET]
DESCRIPTION
This command is used to launch GRASS GIS. It will parse the command line
arguments and then initialize GRASS for the user. Since GRASS programs
require a specific environment, this program must be called before any other
GRASS program can run. The command line arguments are optional and provide
the user with a method to indicate the desired user interface, as well as the
desired mapset to work on.
FEATURES
The grass64 startup program will remember both the desired user
interface and mapset. Thus, the next time the user runs GRASS, typing
grass64 (without any options) will start GRASS with the previous
settings for the user interface and mapset selected.
If you specify a graphical user interface (Tcl/Tk or wxPython) the grass64
program will try to verify that the system you specified exists and that you
can access it successfully. If any of these checks fail then grass64
will automatically switch back to the text user interface mode.
OPTIONS
All command line options are optional.
Flags:
- -
- Tries to start GRASS using location environment variables (see below)
- -h -help --help
- Prints a brief usage message
- -text
- Indicates that the text based user interface should be used
- -gui (or -tcltk)
- Indicates that the old Tcl/Tk based graphical user interface should be used
- -oldtcltk
- Indicates that the even older Tcl/Tk based graphical user interface should be used
- -wxpython (or -wx)
- Indicates that the new Python based graphical user interface should be used
- -v --version
- Prints the version of GRASS and exits
Parameters:
- GISDBASE
- Initial database directory which should be a fully qualified path
(e.g., /usr/local/share/grassdata)
- LOCATION_NAME
- Initial location directory which is a subdirectory of GISDBASE
- MAPSET
- Initial mapset directory which is a subdirectory of LOCATION_NAME
Note- These parameters must be specified in one of the
following ways:
-
MAPSET
LOCATION_NAME/MAPSET
GISDBASE/LOCATION_NAME/MAPSET
ENVIRONMENT VARIABLES
A number of environment variables are available at GRASS startup to assist
with automation and customization. Most users will not need to bother with
these.
In addition to these shell environment variables GRASS maintains a number of
GIS environment variables in the $HOME/.grassrc6 file. User changes
to this file will be read during the next startup of GRASS. If this file
becomes corrupted the user may edit it by hand or remove it to start afresh.
See the list of implemented GRASS variables for
more information.
The rest of this help page will only consider shell environment variables.
User Interface Environment Variable
The grass64 program will check for the existence of an environment
variable called GRASS_GUI which indicates the type of user interface for
GRASS to use. If this variable is not set when grass64 is run, then
it will be created and then saved in the $HOME/.grassrc6 file for
the next time GRASS is run. In addition to "text", "tcltk" or "wxpython",
the GRASS_GUI variable can be set to the name of the Tcl/Tk GUI to use, for
example "gis.m" or "d.m".
There is an order of precedence in the way grass64 determines the user
interface to use. The following is the hierarchy from highest precedence to
lowest.
- Interface precedence
- • Command line argument
• Environment variable GRASS_GUI
• Value set in $HOME/.grassrc6
• Default value - currently gis.m
Tcl/Tk and Python Environment Variables
If you choose to use the Tcl/Tk graphical user interface, then the following
environment variables can be used to override your system default
tclsh and wish commands.
- GRASS_TCLSH
- Command to use to override tclsh
- GRASS_WISH
- Command to use to override wish
- GRASS_PYTHON
- Command to use to override python
Example Use of GRASS Tcl/Tk Environment Variables
Suppose your system has Tcl/Tk 8.3 installed and you install a personal
version of the Tcl/Tk 8.5 binaries under $HOME/bin. You can use
the above variables to have GRASS use the Tcl/Tk 8.5 binaries instead.
GRASS_TCLSH = $HOME/bin/tclsh8.5
GRASS_WISH = $HOME/bin/wish8.5
Example Use of the GRASS Python Environment Variable
GRASS_PYTHON=python2.5
Addon path to extra local GRASS modules
This environment variable allows the user to extend the GRASS program search
paths to include locally developed/installed addon modules which are not
distributed with the standard GRASS release.
GRASS_ADDON_PATH=/usr/mytools
GRASS_ADDON_PATH=/usr/mytools:/usr/local/othertools
In this example above path(s) would be added to the standard GRASS path
environment.
HTML browser variable
The GRASS_HTML_BROWSER environment variable allows the user to set the HTML
web browser to use for dispalying help pages.
Location Environment Variables
The Synopsis and Options sections above describe options that can be used to
set the location and mapset that GRASS will use. These values can also be set
with environment variables. However, specifying the location and mapset
variables on the command line will override these environment variables. The
available variables are as follows:
- LOCATION
- A fully qualified path to a mapset
(eg /usr/local/share/grassdata/spearfish60/PERMANENT). This environment variable
overrides the GISDBASE, LOCATION_NAME, and MAPSET variables.
- GISDBASE
- Initial database directory which should be a fully qualified path
(eg /usr/local/share/grassdata)
- LOCATION_NAME
- Initial location directory which is a subdirectory of GISDBASE
- MAPSET
- Initial mapset directory which is a subdirectory of LOCATION_NAME
Running non-interactive batch jobs
If the GRASS_BATCH_JOB environment variable is set to the full
path and filename of a shell script then GRASS will be launched in a
non-interactive way and the script will be run. The script itself can be
interactive if that is what the user requires. When it is finished GRASS
will automatically exit using the exit-success code given by the script.
The script file must have its executable bit set.
Note
Note that you will need to set these variables using the appropriate method
required for the UNIX shell that you use. (e.g. in a Bash shell you must
"export" the variables for them to propogate)
EXAMPLES
The following are some examples of how you could start GRASS
- grass64
- Start GRASS using the default user interface. The user will be prompted
to choose the appropriate location and mapset.
- grass64 -gui
- Start GRASS using the Tcl/Tk based user interface. The user will be
prompted to choose the appropriate location and mapset.
- grass64 -text
- Start GRASS using the text based user interface. The user will be
prompted to choose the appropriate location and mapset.
- grass64 ~/grassdata/spearfish60/user1
- Start GRASS using the default user interface and automatically launch
into the given mapset, bypassing the mapset selection menu.
- grass64 -gui -
- Start GRASS using the Tcl/Tk based user interface and try to obtain
the location and mapset from environment variables.
Other examples
There are a variety of ways in which the location environment
variables (see above) can be used to specify the mapset to use.
The following are some possible examples.
- Example 1
- The environment variables are defined as follows:
LOCATION = /usr/local/share/grassdata/spearfish60/PERMANENT
GISDBASE = /usr/local/share/grassdata
LOCATION_NAME = spearfish60
MAPSET = PERMANENT
Start GRASS with the following command:
grass64 -
GRASS will start with the mapset defined by LOCATION since the LOCATION
variable overrides the other variables.
- Example 2
- The environment variables are defined as follows:
GISDBASE = /usr/local/share/grassdata
LOCATION_NAME = spearfish60
MAPSET = PERMANENT
Start GRASS with the following command:
grass64 -
GRASS will start with the mapset defined by
GISDBASE/LOCATION_NAME/MAPSET.
- Example 3
- The environment variables are defined as follows:
LOCATION = /usr/local/share/grassdata/spearfish60/PERMANENT
GISDBASE = /usr/local/share/grassdata
LOCATION_NAME = spearfish60
MAPSET = PERMANENT
Start GRASS with the following command:
grass64 /usr/home/grass/data/thailand/forests
GRASS will start with the mapset /home/grass/data/thailand/forests which
overrides the environment variables.
- Example 4
- The environment variables are defined as follows:
LOCATION = /usr/local/share/grassdata/spearfish60/PERMANENT
GISDBASE = /usr/local/share/grassdata
LOCATION_NAME = spearfish60
MAPSET = PERMANENT
Start GRASS with the following command:
grass64 swamps
GRASS will start with the mapset defined by GISDBASE/LOCATION_NAME/swamps
since the command line argument for the mapset overrides the environment
variable MAPSET.
- Example 5
- The environment variables are defined as follows:
LOCATION = /usr/local/share/grassdata/spearfish60/PERMANENT
GISDBASE = /usr/local/share/grassdata
LOCATION_NAME = spearfish60
MAPSET = PERMANENT
Start GRASS with the following command:
grass64 thailand/forests
GRASS will start with the mapset defined by GISDBASE/thailand/forests
since the command line arguments for the location and mapset overrides
the environment variables LOCATION_NAME and MAPSET.
CAVEAT
If you start GRASS using the Tcl/Tk interface you must have a wish
command in your $PATH variable. That is, the command must be named
wish and not something like wish8.3. By default, some Tcl/Tk
installations do not create a wish command. In these cases the system
administrator must create an appropriate link to the actual wish
program.
For example, suppose Tcl/Tk 8.3 programs are installed in /usr/local/bin. Then
the system administrator should go to the /usr/local/bin directory and run the
commands "ln -s wish8.3 wish" and "ln -s tclsh8.3 tclsh" to
properly install Tcl/Tk for use with GRASS.
Furthermore, if you have more than one version of Tcl/Tk installed, make sure
that the version you want to use with GRASS is the first version found in
your $PATH variable. GRASS searches your $PATH variable
until it finds the first version of wish.
FILES
$UNIX_BIN/grass64 - GRASS startup program (Linux, MacOSX etc.)
$WINDOWS_BIN/grass64.bat - GRASS startup program (MS-Windows)
$GISBASE/etc/Init.sh - GRASS initialization script called by
grass64
$GISBASE/etc/gis_set.tcl - Tcl/Tk script to set the
location and mapset to use. Called by Init.sh
SEE ALSO
List of implemented GRASS GIS environment variables.
GRASS GIS Web site
GRASS GIS 6 Programmer's Manual
AUTHORS (of this page)
Justin Hickey
Markus Neteler
Hamish Bowman
Last changed: $Date: 2014-05-14 01:11:57 -0700 (Wed, 14 May 2014) $
Help Index