Using Eclipse 4.5 (Mars) on Windows 7: Difference between revisions
Line 330: | Line 330: | ||
The 'C/C++ Indexer' operation will take some time. Its progress can be monitored in the lower right-hand corner of the screen. Click on the rectangles in the corner to display progress details. | The 'C/C++ Indexer' operation will take some time. Its progress can be monitored in the lower right-hand corner of the screen. Click on the rectangles in the corner to display progress details. | ||
'''Note''': This results in creating the Eclipse .project and .cproject files located in the top-level directory of the GRASS source code installation. | |||
C:\OSGeo4G\src\grass7_trunk | |||
== Create Top-Level Make Targets == | == Create Top-Level Make Targets == |
Revision as of 17:46, 30 August 2015
Introduction
After completing these installation instructions, you will have an IDE for GRASS that will allow you to perform that following development tasks:
Workbench
- Switch between C/C++, Python, Debug and SVN perspectives
Browsing
- Navigate the GRASS source code trunk
- Edit source code
- Select a symbol and go to to its declaration
Building
- Build the entire GRASS system
- Build an individual GRASS module
Running
- Run GRASS modules and Python scripts
Debugging
- Set breakpoints
- Single step through source code
- View variables and memory values
Versioning
- Commit source code to the SVN repository
- Update source code from the SVN repository
Install TortoiseSVN
Download and install from the TortoiseSVN website.
During installation, include the "entire command line tools" so that "svn up" can be run from a Windows Command Prompt or MSYS shell.
The following path should have been added to PATH:
C:\Program Files\TortoiseSVN\bin
From Command Prompt, enter the following command:
>where svn
To run "svn up" from a Command Prompt, enter the following commands:
>cd C:\OSGeo4W\src\grass7_trunk >svn up
To run "svn up" from a MSYS shell, enter the following commands:
$ export PATH=$PATH:/c/"Program Files"/TortoiseSVN/bin $ cd /c/OSGeo4W/src/grass7_trunk $ svn up
Install OSGeo4W Runtime and Development Framework
Download and install the 32bit version from the OSGeo4W website.
It will be installed in this directory:
C:\OSGeo4W
Checkout GRASS Source Code and Make Debug Build
Checkout the GRASS development branch using the SVN command from the GRASS Download website.
Open a MSYS shell.
$ cd /c/OSGeo4W/src $ export PATH=$PATH:/c/"Program Files"/TortoiseSVN/bin $ which svn $ svn checkout https://svn.osgeo.org/grass/grass/trunk grass7_trunk
Run a 'debug' build.
$ cd /c/OSGeo4W/src/grass7_trunk $ export CFLAGS='-g -Wall' $ ./mswindows/osgeo4w/package.sh
This will take some time to complete.
Build activity is logged to this file:
C:\OSGeo4W\src\grass7_trunk\mswindows\osgeo4w\package.log
In addition to building and installing GRASS, which can be run using the created Windows desktop icon, the Eclipse workbench will be able to use these artifacts that are created during a GRASS build:
- Top-level Makefile
- Module-level Makefiles
- Symbol tables added to runtime binaries
Makefiles allow the Eclipse workbench to re-build the entire GRASS system or to re-build individual GRASS modules after source code editing.
Symbol tables allow the Eclipse debugger (GDB) to set break-points in source code, single step through source code, and view the values of source code variables and structures.
Install Doxygen and Make Documentation
Install latest Doxygen binary distribution for Windows.
Download and install from the | Doxygen website.
Install latest Graphviz binary distribution for windows.
Download and install from the | Graphviz website.
Install latest basic TeX/LaTeX system for Windows.
Download and install from the | MikTeX website.
After the TeX/LaTeX system is installed, and during the first time "make pdfdocs" is run, expect to be prompted for additional packages that must be installed to complete the TeX/LaTex system.
Open a MSYS shell.
$ export PATH=$PATH:/c/"Program Files"/doxygen/bin $ export PATH=$PATH:/c/graphviz-2.38/release/bin $ export PATH=$PATH:/c/"Program Files (x86)"/"MiKTeX 2.9"/miktex/bin $ echo $PATH $ cd /c/OSGeo4W/src/grass7_trunk/ $ make htmldocs $ make pdfdocs
Open the HTML formatted documentation using a web browser:
file:///C:/OSGeo4W/src/grass7_trunk/html/index.html
Install GRASS Database
In your Windows Home directory, create a directory named 'grassdata'.
Example:
C:\Users\Ruth\grassdata
Download one or more GRASS 7 datasets from the GRASS GIS sample data download website to the 'grassdata' directory and decompress.
This tutorial uses the 'complete NC location' dataset.
After the 'complete NC location' has been decompressed in the 'grassdata' directory, you should see this sub-directory:
nc_spm_08_grass7
Install Eclipse Mars
Download and install the 32bit version of Java SE Runtime Environment (JRE) from the Java Download website.
Download and install the 32bit version of Eclipse IDE for C/C++ Developers from the Eclipse Mars Download website.
This tutorial installed Eclipse in this directory:
C:\eclipse-4.5-mars-32bit
Install PyDev Plug-In
Start Eclipse.
Help -> Install New Software... Select "Add..". Enter "PyDev" in the "Name: field. Enter "http://pydev.org/updates/" in the Location" field. "OK"
Check the "PyDev" option. "Next" "Next" Accept the license agreement. "Finish"
Restart Eclipse.
Install SVN Plug-In
Start Eclipse.
Install SVN plug-in.
Help -> Install New Software... Set "Work with:" to "Mars - http://download.eclipse.org/releases/mars". Expand "Collaboration". Scroll down and put a check mark in the "Subversive SVN Team Provider option. "Next" "Next" Accept the license agreement. "Finish"
Restart Eclipse.
When "Subversive Connector Discovery" prompts you for a selection, check "SVN Kit 1.8.10". "Finish" "Next" "Next" Accept the license agreement. "Finish" "OK" to the "security Warning".
Restart Eclipse.
Make SVN visible.
Window → Perspective → Customize Perspective... Select the "Action Set Availability" tab. Check the "SVN" option under "Available action sets". "OK"
Window → Perspective → Customize Perspective... Select the "Shortcuts" tab. Check the "SVN" option under "Shortcut Categories". Select the "Menu Visibility" tab. Check the "SVN" option under "Menu Structure". Select the "Tool Bar Visibility" tab. Check the "SVN" option under "Tool Bar Structure". "OK"
You should now see "SVN" on the main tool bar and the SVN tool bar available under the main toolbar.
Setup Eclipse GRASS Environment
We will start Eclipse from a Windows batch file. This will provide the opportunity to set environment variable required by both the GRASS runtime modules and the Eclipse workbench.
1. Exit Eclipse.
File -> Exit
2. Install eclipse.bat.
Using a text editor, create a Windows batch file named eclipse.bat in the top-level directory where Eclipse is installed.
The top-level Eclipse directory used in this tutorial is:
C:\eclipse-4.5-mars-32bit
Copy the contents from eclipse.bat to the eclipse.bat file you created.
Modify the contents for your particular Windows and GRASS development environment.
Save and exit eclipse.bat.
Reference: Working with GRASS without starting it explicitly
3. Update Eclipse Icon Properties.
Update the Properties of the Eclipse startup icon that is on your Windows desktop.
Right-click on the desktop icon and change the Target field to something like this:
C:\Windows\System32\cmd.exe /D /K C:\eclipse-4.5-mars-32bit\eclipse.bat
Select 'OK' to save the change.
Configure Eclipse Settings
Enable C/C++ Perspective
Window -> Perspective -> Open Perspective Select 'Other...' Select 'C/C++' 'OK'
Enable Python Perspective
Window -> Perspective -> Open Perspective Select 'Other...' Select 'PyDev' 'OK'
Enable Debug Perspective
Window -> Perspective -> Open Perspective Select 'Other...' Select 'Debug' 'OK'
Enable SVN Perspective
Window -> Perspective -> Open Perspective Select 'Other...' Select 'SVN Repository Exploring' 'OK'
Insert Spaces for Tabs
Window -> Preferences -> General -> Editors -> Text Editors Set 'Displayed tab width' to 4. Check 'Insert spaces for tabs'. 'Apply' 'OK'
Window -> Preferences -> C/C++ -> Code Style -> Formatter Select the 'New' button to create a new profile. Enter 'GRASS' in the 'Profile name' field. Select 'OK'. Select the 'Indentation' tab. Under 'General settings', set Tab policy to 'Spaces only'. 'OK'
Uncheck Build Automatically
'Project' -> 'Build Automatically' to uncheck this option.
Change Color of Python Comments
Window -> Preferences Expand 'PyDev'. Select 'Editor'. In the 'Appearance color options' window: Scroll down to 'Comments' and select. Click on the 'Color' button to bring up options. Select the green color that is located in the 3rd column from the left and 4th row from the top. 'OK' 'Apply' 'OK'
Create C/C++ Project
Create a C++, Makefile, Empty project
"File" -> "New" -> "Project..." Expand "C/C++" option. Select "C++ Project" "Next"
Uncheck 'Use default location'. Browse to 'C:\OSGeo4W\src\grass7_trunk'. 'OK' Enter 'grass7_trunk' in the "Project name" field. Expand 'Makefile project' under 'Project type'. Select 'Empty Project' under 'Project type'. Select 'MinGW GCC' under 'Toolchains'. "Next"
Click on 'Advanced settings...' Click on 'C/C++ Build'. Click on the 'Behavior' tab. Leave 'Build (Incremental Build)' Checked. Enter 'default' in the text box next to 'Build (Incremental Build)' replacing any text that is already there (e.g., 'all'). 'Apply' 'OK' 'Finish'
The 'grass7_trunk' project will appear in the 'Project Explorer' view.
The 'C/C++ Indexer' operation will take some time. Its progress can be monitored in the lower right-hand corner of the screen. Click on the rectangles in the corner to display progress details.
Note: This results in creating the Eclipse .project and .cproject files located in the top-level directory of the GRASS source code installation.
C:\OSGeo4G\src\grass7_trunk
Create Top-Level Make Targets
Right-click on 'grass7_trunk' in the 'Windows Explorer' view. Select "Make Targets" Select "Create..." Enter 'default' in the 'Target name' field. 'OK'
Do the same for each of the following targets:
install clean distclean libs libsclean cleandistdirs cleanscriptstrings manifests
Run a GRASS Script
Open Project.
Right-click on 'grass7_trunk' in the 'Windows Explorer' view. Click on 'Open Project'. The Indexer and SVN cache updates will take a moment to complete.
Switch to 'PyDev' Perspective.
Click the 'PyDev' button on the 'Perspective' tool bar.
Configure Script.
Click on 'Run' on the main task bar. Hover over 'Run As' and select 'Run configurations...' from the pop-up list. Right-click on 'Python Run' and select 'New'. Enter 'm.proj.py' in the 'Name' field. Click the 'Project' 'Browse...' button. Select 'grass7_trunk'. 'OK' Click the 'Main Module' 'Browse...' button. Scroll down and enter the 'scripts' -> 'm.proj' folder and select 'm.proj.py'. 'OK' Select the 'Arguments' tab. Enter the following string in the 'Program arguments' window: coordinates=-111d30,45d15.551666667N proj_out="+proj=utm +zone=10 +datum=NAD27" proj_in="+proj=latlong +datum=NAD83" --v 'Apply' 'Run'
Output from the run will be displayed in the 'Console' window.
Run Script.
'Run' -> 'Run'
Output from the run will be displayed in the 'Console' window.
Change the run focus.
'Run' Click on 'Run configurations...'. Select a configured script under 'Python Run'. 'Run'
Output from the run will be displayed in the 'Console' window.
Note: The first time a run configuration for a Python script is performed, Eclipse discovers that it must add the Python (PyDev) 'nature' to the project. This results in creating the .pydevproject file and updating the .project file located in the top-level directory where the GRASS source code was installed.
C:\OSGeo4G\src\grass7_trunk
Run a GRASS Module
Open Project.
Right-click on 'grass7_trunk' in the 'Windows Explorer' view. Click on 'Open Project'. The Indexer and SVN cache updates will take a moment to complete.
Switch to 'C/C++' Perspective.
Click the 'C/C++' button on the 'Perspective' tool bar.
Configure Module.
Click on 'Run' on the main task bar. Select 'Run configurations...' from the pop-up list. Right-click on 'C/C++ Application' and select 'New'. Enter 'r.univar' in the 'Name' field. Click the 'Project' 'Browse...' button. Select 'grass7_trunk'. 'OK' Click the 'C/C++ Applications' 'Search Project...' button. Scroll down and select 'r.univar.exe'. 'OK' 'Apply' Select the 'Arguments' tab. Enter the following string in the 'Program arguments' window: map=aspect@PERMANENT 'Apply' 'Run'
Output from the run will be displayed in the 'Console' window.
Run Module.
'Run' -> 'Run'
Output from the run will be displayed in the 'Console' window.
Change the run focus.
'Run' Click on 'Run configurations...'. Select a configured application under 'C/C++ Application'. 'Run'
Output from the run will be displayed in the 'Console' window.