grasslib.dox 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. /*! \mainpage GRASS 7 Programmer's Manual
  2. <!-- * doxygenized from "GRASS 5 Programmer's Manual"
  3. by M. Neteler 2/2004
  4. * updated 8/2005, 2006, 2007, 2008
  5. -->
  6. <a href="http://grass.osgeo.org">GRASS GIS</a> (<b>Geographic
  7. Resources Analysis Support System</b>) is an open source, Free
  8. Software <em>Geographical Information System</em> (GIS) with raster,
  9. topological %vector, image processing, and graphics production
  10. functionality that operates on various platforms through a graphical
  11. user interface (GUI) or command line interface (CLI). It is released
  12. under GNU General Public License (GPL).
  13. This manual introduces the reader to the <i>Geographic Resources
  14. Analysis Support System</i> from the programming perspective. Design
  15. theory, system support libraries, system maintenance, and system
  16. enhancement are all presented. Standard GRASS 4.x conventions are
  17. still used in much of the code. This work is part of ongoing research
  18. being performed by the <a
  19. href="http://grass.osgeo.org/community/team.php">GRASS Development
  20. Team</a>, an international team of programmers, GRASS module authors
  21. are cited within their module's source code and the contributed manual
  22. pages.
  23. &copy; 2000-2010 GRASS Development Team
  24. Published under <a href="http://www.fsf.org/copyleft/fdl.html">GNU Free Documentation License</a> (GFDL)
  25. This manual comes with ABSOLUTELY NO WARRANTY. The development of
  26. GRASS software and this manual is kindly supported by the <a
  27. href="http://www.osgeo.org">Open Source Geospatial Foundation</a>, who
  28. provides the GRASS main infrastructure.
  29. Main web site: <a href="http://grass.osgeo.org">http://grass.osgeo.org</a>
  30. <b>Table of contents</b>
  31. - \subpage corelibs
  32. - \subpage libs
  33. - \subpage interfaces
  34. - \subpage gui
  35. - \subpage location
  36. - \subpage Compiling_and_Installing_GRASS_Modules
  37. - \subpage Makefile_Variables
  38. - \subpage Constructing_a_Makefile
  39. - \subpage Multiple_Architecture_Conventions
  40. - \subpage vectmodules
  41. - \subpage vectmodules_oper
  42. <i>Missing entries below are either not yet uploaded to SVN (need to
  43. be migrated from GRASS 5 Programmer's manual) or are simply
  44. undocumented.</i>
  45. <!-- original:
  46. http://trac.osgeo.org/grass/browser/grass-web/trunk/images/grass7_arch.odp
  47. -->
  48. \image html "grass7_arch.png" "GRASS 7 Architecture"
  49. <p>
  50. <b>PLEASE UPDATE FOR GRASS 7</b>
  51. \section corelibs Principal library
  52. (the name refers to the directory name in lib/ in the source code)
  53. - gis: \ref gislib
  54. - raster: \ref rasterlib
  55. - vector: \ref vectorlib
  56. \section libs Further libraries
  57. (the name refers to the directory name in lib/ in the source code)
  58. - arraystats: Library of statistics for arrays of doubles - \ref arraystats (new, under development)
  59. - bitmap: Bitmap library for X Window Bitmaps - \ref bitmap
  60. - btree: Binary tree library - \ref btree
  61. - cairodriver: \ref cairodriver
  62. - cdhc: Library for testing normality and exponentiality - \ref cdhc
  63. - cluster: \ref clusterlib (image processing)
  64. - datetime: DateTime library - \ref datetime
  65. - db: \ref dbmilib
  66. - display: \ref displaylib
  67. - %driver: Graphics monitor driver
  68. - dspf: DSPF libary - \ref dspf (obsolete?)
  69. - edit: Raster edit library (cellhd, history, cats) - \ref edit
  70. - external: External libraries from other projects (such as shapelib) - \ref external
  71. - fonts: Hershey library - \ref fonts
  72. - g3d: \ref g3dlib
  73. - gmath: \ref gmathlib (generic mathematical functions and BLAS/LAPACK library wrapper)
  74. - gpde: \ref gpdelib (partial differential equations library)
  75. - imagery: \ref imagerylib
  76. - init: \ref init (GRASS initialization code + scripts)
  77. - linkm: Linked list memory manager - \ref linkm (obsolete?)
  78. - ogsf: \ref ogsflib (OpenGL (R) ported gsurf library (required for NVIZ))
  79. - pngdriver: PNG display driver library - \ref pngdriver
  80. - proj: \ref projlib (wrapper to PROJ4 projection library)
  81. - psdriver: PostScript display driver library - \ref psdriver
  82. - python: \ref pythonlib
  83. - raster: \ref rasterlib
  84. - rowio: \ref rowiolib
  85. - rst: Library for interpolation with regularized splines with tension - \ref rst
  86. - segment: \ref segmentlib (segment library for segmented raster reading)
  87. - sites: Old Sites library, now interfaced to \ref vectorlib - \ref sites
  88. - stats: Raster stats library - \ref stats
  89. - symbol: Drawing symbols for %point %vector data library - \ref symbol
  90. - vask: Cursor management library - \ref vask
  91. - %vector: \ref vectorlib (GRASS Vector and Direct Graph Library)
  92. - vedit: \ref veditlib - %vector editing
  93. - neta: \ref netalib
  94. - nviz: \ref nvizlib (used by wxGUI Nviz extension and CLI-based Nviz module)
  95. \section interfaces Interfaces
  96. - \ref swiglib
  97. - \ref pythonlib
  98. \section gui GUI
  99. - \ref wxpythonlib
  100. \section location File structure of GRASS Location
  101. A GRASS <b>raster map</b> consists of several files in several subdirectories in a mapset,
  102. organized as follows:
  103. - <b>cellhd/</b>:
  104. map header including projection code, coordinates representing
  105. the spatial extent of the raster map, number of rows and columns, resolution,
  106. and information about map compression;</li>
  107. - <b>cell/, fcell/ or grid3/</b>:
  108. generic matrix of values in a compressed, portable
  109. format which depends on the raster data type (integer, floating %point or 3D grid);</li>
  110. - <b>hist/</b>:
  111. history file which contains metadata such as the data source,
  112. the command that was used to generate the raster map, or
  113. other information provided by the user;</li>
  114. - <b>cats/</b>:
  115. optional category file which contains text or numeric labels assigned
  116. to the raster map categories;</li>
  117. - <b>colr/</b>:
  118. optional color table;</li>
  119. - <b>cell_misc/</b>:
  120. optional timestamp, range of values, quantization rules (for floating %point maps)
  121. and null (no-data) files; </li>
  122. A GRASS <b>%vector maps</b> are stored in several separate files in a
  123. single directory (see \ref vectorlib). While the
  124. attributes are stored in either a DBF file, a SQLite file or in an
  125. external DBMS (PostgreSQL, MySQL, ODBC), the geometric data are saved
  126. as follows:
  127. - <b>head</b>: %vector map ASCII header with information about the map creation
  128. (date and name), its scale and threshold;</li>
  129. - <b>coor</b>: binary geometry file which includes the coordinates of graphic
  130. elements (primitives) that define the %vector feature;</li>
  131. - <b>topo</b>: binary topology file describes the spatial relationships between the
  132. map's graphic elements;</li>
  133. - <b>hist</b>: history ASCII file with complete commands that were used to
  134. create the %vector map, as well as the name and date/time of the map
  135. creation;</li>
  136. - <b>cidx</b>: binary category index file which is used to %link the %vector
  137. object IDs to the attribute table rows;</li>
  138. - <b>dbln</b>: ASCII file which contains definition(s) of %link to attribute
  139. storage in database (DBMS).</li>
  140. <!-- original:
  141. http://trac.osgeo.org/grass/browser/grass-web/trunk/images/loc_struct.odg
  142. -->
  143. \image html "loc_struct.png" "Diagram of GRASS file structure"
  144. \section Compiling_and_Installing_GRASS_Modules Compiling and Installing GRASS Modules
  145. GRASS modules are compiled and installed using the UNIX <tt>make</tt>
  146. command, which reads a file named <tt>Makefile</tt> (see \ref
  147. Multiple_Architecture_Conventions for more information) and then runs
  148. the compiler. The GRASS compilation process allows for
  149. multiple-architecture compilation from a single copy of the source
  150. code (for instance, if the source code is NFS mounted to various
  151. machines with differing architectures). This chapter assumes that the
  152. programmer is familiar with <tt>make</tt> and its accompanying
  153. Makefile.
  154. \todo Explain ''auto-conf''
  155. \todo Include contents of SUBMITTING and INSTALL files from source code
  156. To compile enter following:
  157. \verbatim
  158. ./configure
  159. make
  160. make install
  161. \endverbatim
  162. Then the code will be compiled into "/usr/local/grass-7.x.y" directory. The start
  163. script "grass7x" will be placed into "/usr/local/bin/".
  164. Optionally other target directories can be specified while "configuring":
  165. \verbatim
  166. ./configure --prefix=/opt/grass-7.x.y --with-bindir=/usr/bin
  167. make
  168. make install
  169. \endverbatim
  170. This will store the GRASS binaries into the directory
  171. "/opt/grass-7.x.y" and the script mentioned above into "/usr/bin".
  172. The script "make" is required to compile single modules. The
  173. compilation process and requirements are discussed in more detail now.
  174. \subsection Makefile_Variables Makefile Variables
  175. \todo Update the list.
  176. <b>GRASS Libraries</b>. The following variables name the various GRASS
  177. libraries:
  178. - <i>GISLIB</i> - This names the <b>GIS Library</b>, which is the
  179. principal GRASS library. See \ref GIS_Library for details about this
  180. library, and \ref Loading_the_GIS_Library for a sample Makefile which
  181. loads this library.
  182. - <i>SEGMENTLIB</i> - This names the <b>Segment Library</b>, which
  183. manages large matrix data. See \ref Segment_Library for details about
  184. this library, and \ref Loading_the_Vask_Library for a sample
  185. <i>Makefile</i> which loads this library.
  186. - <i>RASTERLIB</i> - This names the <b>Raster Graphics Library</b>,
  187. which communicates with GRASS graphics drivers. See \ref
  188. Raster_Graphics_Library for details about this library, and \ref
  189. Loading_the_Raster_Graphics_Library for a sample <i>Makefile</i> which
  190. loads this library.
  191. - <i>DISPLAYLIB</i> - This names the <b>Display Graphics Library</b>,
  192. which provides a higher level graphics interface to
  193. <i>RASTERLIB</i>. See Display_Graphics_Library for details about this
  194. library, and Loading_the_Display_Graphics_Library for a sample
  195. <i>Makefile</i> which loads this library.
  196. <b>UNIX Libraries:</b> The following variables name some useful UNIX
  197. system libraries:
  198. - <i>MATHLIB</i> This names the math library. It should be used
  199. instead of the -lm loader option.
  200. - <i>CURSES</i> This names both the curses and termcap libraries. It
  201. should be used instead of the -lcurses/-lncurses and
  202. -ltermcap loader options. Do not use <tt>$CURSES</tt> if you use
  203. <tt>$VASK</tt>.
  204. - <i>TERMLIB</i> This names the termcap library. It should be used
  205. -instead of the ltermcap or -ltermlib loader options. Do not use
  206. -<tt>$TERMLIB</tt> if you use <tt>$VASK</tt> or <tt>$CURSES</tt>.
  207. <b>Compiler and loader variables.</b> The following variables are
  208. related to compiling and loading C programs:
  209. - <i>EXTRA\_CFLAGS</i> This variable can be used to add additional
  210. options to <tt>$CFLAGS</tt>. It has no predefined values. It is
  211. usually used to specify additional -I include directories, or -D
  212. preprocessor defines.
  213. \subsection Constructing_a_Makefile Constructing a Makefile
  214. The complete syntax for a <i>Makefile</i> is discussed in the UNIX
  215. documentation for <tt>make</tt> and will not be repeated here. The
  216. essential idea is that a target (e.g. a GRASS module) is to be built
  217. from a list of dependencies (e.g. object files, libraries, etc.). The
  218. relationship between the target, its dependencies, and the rules for
  219. constructing the target is expressed according to the following
  220. syntax:
  221. \code
  222. target: dependencies
  223. actions
  224. more actions
  225. \endcode
  226. If the target does not exist, or if any of the dependencies have a newer
  227. date than the target (i.e., have changed), the actions will be executed to
  228. build the target. The actions must be indented using a TAB. <tt>make</tt> is
  229. picky about this. It does not like spaces in place of the TAB.
  230. \section Multiple_Architecture_Conventions Multiple-Architecture Conventions
  231. The following conventions allow for multiple architecture compilation on a
  232. machine that uses a common or networked GRASS source code directory tree.
  233. Object files and library archives are compiled into subdirectories
  234. that represent the architecture that they were compiled on. These
  235. subdirectories are created in the $SRC directory as OBJ.<tt>arch</tt>
  236. and LIB.<tt>arch</tt>, where <tt>arch</tt> represents the architecture
  237. of the compiling machine. Thus, for example, $SRC/OBJ.sun4 would
  238. contain the object files for Sun/4 and SPARC architectures, and
  239. <tt>$SRC/LIB.686-pc-linux-gnu</tt> would contain library archives for
  240. Linux architectures. Likewise, <tt>$SRC/OBJ.686-pc-linux-gnu</tt>
  241. would contain the object files for Linux architectures, and
  242. <tt>$SRC/LIB.686-pc-linux-gnu</tt> would contain library archives for
  243. Linux architectures.
  244. Note that 'arch' is defined for a specific architecture during setup and
  245. compilation of GRASS, it is not limited to sun4 or any specific string.
  246. \section vectmodules Vector modules and their parameters/flags
  247. A module is a GRASS command invoked by the user.
  248. \subsection vectmodules_oper Modules operation
  249. Each module which modifies and writes data must read from
  250. <b>input=</b> and write to <b>output=</b> so that data may not be
  251. lost. For example <tt>v.spag</tt> works on <b>map=</b> at in GRASS GIS
  252. 5.0 but if program (system) crashes or threshold was specified
  253. incorrectly and vector was not backuped, data were lost. In this case
  254. </b>map=</b> option should be replaced by <b>input=</b> and
  255. <b>output=</b>.
  256. Topology is always built by default if the coor file was modified.
  257. Dimensionality is generally kept. Input 2D vector is written as 2D, 3D
  258. as 3D. There are a few modules which change the dimension on purpose.
  259. \subsection vectmodulesopt Modules parameters/flags
  260. <b>-b</b> do not build topo file; by default topo file is written
  261. <b>-t</b> create new table, default
  262. <b>-u</b> don't create new table
  263. <b>-z</b> write 3D vector map (if input was 2D)
  264. <b>map=</b> input vector map for modules without output
  265. <b>input=</b> input vector map
  266. <b>output=</b> output vector map
  267. <b>type=</b> type of elements: point,line,boundary,centroid,area
  268. <b>cat=</b> category or category list (example: 1,5,9-13,35)
  269. <b>layer=</b> layer number
  270. <b>where=</b> condition of SQL statement for selection of records
  271. <b>column=</b> column name (in external table)
  272. */