ogrgrassdatasource.cpp
来自「支持各种栅格图像和矢量图像读取的库」· C++ 代码 · 共 303 行
CPP
303 行
/****************************************************************************** * $Id: ogrgrassdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project: OpenGIS Simple Features Reference Implementation * Purpose: Implements OGRGRASSDataSource class. * Author: Radim Blazek, radim.blazek@gmail.com * ****************************************************************************** * Copyright (c) 2005, Radim Blazek <radim.blazek@gmail.com> * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. ****************************************************************************/#include "ogrgrass.h"#include "cpl_conv.h"#include "cpl_string.h"CPL_CVSID("$Id: ogrgrassdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//* Grass2CPLErrorHook() *//************************************************************************/int Grass2OGRErrorHook( char * pszMessage, int bFatal ){ if( !bFatal ) CPLError( CE_Warning, CPLE_AppDefined, "GRASS warning: %s", pszMessage ); else CPLError( CE_Warning, CPLE_AppDefined, "GRASS fatal error: %s", pszMessage ); return 0;}/************************************************************************//* OGRGRASSDataSource() *//************************************************************************/OGRGRASSDataSource::OGRGRASSDataSource(){ pszName = NULL; pszGisdbase = NULL; pszLocation = NULL; pszMapset = NULL; pszMap = NULL; papoLayers = NULL; nLayers = 0;}/************************************************************************//* ~OGRGRASSDataSource() *//************************************************************************/OGRGRASSDataSource::~OGRGRASSDataSource(){ CPLDebug ( "GRASS", "OGRGRASSDataSource::~OGRGRASSDataSource()" ); for( int i = 0; i < nLayers; i++ ) delete papoLayers[i]; if ( pszName ) CPLFree( pszName ); if ( papoLayers ) CPLFree( papoLayers ); if ( pszGisdbase ) CPLFree( pszGisdbase ); if ( pszLocation ) CPLFree( pszLocation ); if ( pszMapset ) CPLFree( pszMapset ); if ( pszMap ) CPLFree( pszMap );}/************************************************************************//* Open() *//************************************************************************/typedef int (*GrassErrorHandler)(char *, int);int OGRGRASSDataSource::Open( const char * pszNewName, int bUpdate, int bTestOpen, int bSingleNewFileIn ){ CPLDebug ( "GRASS", "OGRGRASSDataSource::Open" ); VSIStatBuf stat; CPLAssert( nLayers == 0 ); pszName = CPLStrdup( pszNewName ); // Released by destructor/* -------------------------------------------------------------------- *//* Do the given path contains 'vector' and 'head'? *//* -------------------------------------------------------------------- */ if ( strstr(pszName,"vector") == NULL || strstr(pszName,"head") == NULL ) { if( !bTestOpen ) { CPLError( CE_Failure, CPLE_AppDefined, "%s is not GRASS vector, access failed.\n", pszName ); } return FALSE; } /* -------------------------------------------------------------------- *//* Is the given a regular file? *//* -------------------------------------------------------------------- */ if( CPLStat( pszName, &stat ) != 0 || !VSI_ISREG(stat.st_mode) ) { if( !bTestOpen ) { CPLError( CE_Failure, CPLE_AppDefined, "%s is not GRASS vector, access failed.\n", pszName ); } return FALSE; }/* -------------------------------------------------------------------- *//* Parse datasource name *//* -------------------------------------------------------------------- */ if ( !SplitPath(pszName, &pszGisdbase, &pszLocation, &pszMapset, &pszMap) ) { if( !bTestOpen ) { CPLError( CE_Failure, CPLE_AppDefined, "%s is not GRASS datasource name, access failed.\n", pszName ); } return FALSE; } CPLDebug ( "GRASS", "Gisdbase: %s", pszGisdbase ); CPLDebug ( "GRASS", "Location: %s", pszLocation ); CPLDebug ( "GRASS", "Mapset: %s", pszMapset ); CPLDebug ( "GRASS", "Map: %s", pszMap );/* -------------------------------------------------------------------- *//* Init GRASS library *//* -------------------------------------------------------------------- */ // GISBASE is path to the directory where GRASS is installed, // it is necessary because there are database drivers. if ( !getenv( "GISBASE" ) ) { char *gisbase = GRASS_GISBASE; CPLError( CE_Warning, CPLE_AppDefined, "GRASS warning: GISBASE " "enviroment variable was not set, using:\n%s", gisbase ); char buf[2000]; sprintf ( buf, "GISBASE=%s", gisbase ); char *gisbaseEnv = CPLStrdup ( buf ); putenv( gisbaseEnv ); } // Don't use GISRC file and read/write GRASS variables // (from location G_VAR_GISRC) to memory only. G_set_gisrc_mode ( G_GISRC_MODE_MEMORY ); // Init GRASS libraries (required). G_no_gisinit() doesn't check // write permissions for mapset compare to G_gisinit() G_no_gisinit(); // Set error function G_set_error_routine ( (GrassErrorHandler) Grass2OGRErrorHook );/* -------------------------------------------------------------------- *//* Set GRASS variables *//* -------------------------------------------------------------------- */ G__setenv( "GISDBASE", pszGisdbase ); G__setenv( "LOCATION_NAME", pszLocation ); G__setenv( "MAPSET", pszMapset); G_reset_mapsets(); G_add_mapset_to_search_path ( pszMapset );/* -------------------------------------------------------------------- *//* Open GRASS vector map *//* -------------------------------------------------------------------- */ Vect_set_fatal_error ( GV_FATAL_PRINT ); // Print error and continue Vect_set_open_level (2); int level = Vect_open_old ( &map, pszMap, pszMapset); if ( level < 2 ) { CPLError( CE_Failure, CPLE_AppDefined, "Cannot open GRASS vector %s on level 2.\n", pszName ); return FALSE; } CPLDebug ( "GRASS", "Num lines = %d", Vect_get_num_lines(&map) ); /* -------------------------------------------------------------------- *//* Build a list of layers. *//* -------------------------------------------------------------------- */ int ncidx = Vect_cidx_get_num_fields ( &map ); CPLDebug ( "GRASS", "Num layers = %d", ncidx ); for ( int i = 0; i < ncidx; i++ ) { // Create the layer object OGRGRASSLayer *poLayer; poLayer = new OGRGRASSLayer( i, &map ); // Add layer to data source layer list papoLayers = (OGRGRASSLayer **) CPLRealloc( papoLayers, sizeof(OGRGRASSLayer *) * (nLayers+1) ); papoLayers[nLayers++] = poLayer; } return TRUE;}/************************************************************************//* CreateLayer() *//************************************************************************/OGRLayer *OGRGRASSDataSource::CreateLayer( const char * pszLayerName, OGRSpatialReference *poSRS, OGRwkbGeometryType eType, char ** papszOptions ){ CPLError( CE_Failure, CPLE_NoWriteAccess, "CreateLayer is not supported by GRASS driver" ); return NULL;}/************************************************************************//* TestCapability() *//************************************************************************/int OGRGRASSDataSource::TestCapability( const char * pszCap ){ return FALSE;}/************************************************************************//* GetLayer() *//************************************************************************/OGRLayer *OGRGRASSDataSource::GetLayer( int iLayer ){ if( iLayer < 0 || iLayer >= nLayers ) return NULL; else return papoLayers[iLayer];}/************************************************************************//* SplitPath() *//* Split full path to cell or group to: *//* gisdbase, location, mapset, name *//* New string are allocated and should be freed when no longer needed. *//* *//* Returns: true - OK *//* false - failed *//************************************************************************/bool OGRGRASSDataSource::SplitPath( char *path, char **gisdbase, char **location, char **mapset, char **map ){ char *p, *ptr[5], *tmp; int i = 0; CPLDebug ( "GRASS", "OGRGRASSDataSource::SplitPath" ); *gisdbase = *location = *mapset = *map = NULL; if ( !path || strlen(path) == 0 ) return false; tmp = G_store ( path ); while ( (p = strrchr(tmp,'/')) != NULL && i < 5 ) { *p = '\0'; if ( strlen(p+1) == 0 ) /* repeated '/' */ continue; ptr[i++] = p+1; } /* Note: empty GISDBASE == 0 is not accepted (relative path) */ if ( i != 5 ) { free ( tmp ); return false; } if ( strcmp(ptr[0],"head") != 0 || strcmp(ptr[2],"vector") != 0 ) { return false; } *gisdbase = G_store ( tmp ); *location = G_store ( ptr[4] ); *mapset = G_store ( ptr[3] ); *map = G_store ( ptr[1] ); free ( tmp ); return true;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?