亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ogrtigerdatasource.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/****************************************************************************** * $Id: ogrtigerdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  TIGER/Line Translator * Purpose:  Implements OGRTigerDataSource class * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 1999, Frank Warmerdam <warmerdam@pobox.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 "ogr_tiger.h"#include "cpl_conv.h"#include "cpl_string.h"#include <ctype.h>CPL_CVSID("$Id: ogrtigerdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                        TigerClassifyVersion()                        *//************************************************************************/TigerVersion TigerClassifyVersion( int nVersionCode ){    TigerVersion        nVersion;    int                 nYear, nMonth;/*** TIGER Versions**** 0000           TIGER/Line Precensus Files, 1990 ** 0002           TIGER/Line Initial Voting District Codes Files, 1990 ** 0003           TIGER/Line Files, 1990 ** 0005           TIGER/Line Files, 1992 ** 0021           TIGER/Line Files, 1994 ** 0024           TIGER/Line Files, 1995 ** 9706 to 9810   TIGER/Line Files, 1997 ** 9812 to 9904   TIGER/Line Files, 1998 ** 0006 to 0008   TIGER/Line Files, 1999 ** 0010 to 0011   TIGER/Line Files, Redistricting Census 2000** 0103 to 0108   TIGER/Line Files, Census 2000**** 0203 to 0205   TIGER/Line Files, UA 2000** ????    ????**** 0206 to 0299   TIGER/Line Files, 2002** 0300 to 0399   TIGER/Line Files, 2003** 0400+          TIGER/Line Files, 2004 - one sample is 0405** ????*/    nVersion = TIGER_Unknown;    if( nVersionCode == 0 )        nVersion = TIGER_1990_Precensus;    else if( nVersionCode == 2 )        nVersion = TIGER_1990;    else if( nVersionCode == 3 )        nVersion = TIGER_1992;    else if( nVersionCode == 5 )        nVersion = TIGER_1994;    else if( nVersionCode == 21 )        nVersion = TIGER_1994;    else if( nVersionCode == 24 )        nVersion = TIGER_1995;    else if( nVersionCode == 9999 )  /* special hack, fme bug 7625 */        nVersion = TIGER_UA2000;    nYear = nVersionCode % 100;    nMonth = nVersionCode / 100;    nVersionCode = nYear * 100 + nMonth;    if( nVersion != TIGER_Unknown )        /* do nothing */;    else if( nVersionCode >= 9706 && nVersionCode <= 9810 )        nVersion = TIGER_1997;    else if( nVersionCode >= 9812 && nVersionCode <= 9904 )        nVersion = TIGER_1998;    else if( nVersionCode >=    6 /*0006*/ && nVersionCode <=    8 /*0008*/ )        nVersion = TIGER_1999;    else if( nVersionCode >=   10 /*0010*/ && nVersionCode <=   11 /*0011*/ )        nVersion = TIGER_2000_Redistricting;    else if( nVersionCode >=  103 /*0103*/ && nVersionCode <= 108 /*0108*/ )        nVersion = TIGER_2000_Census;    else if( nVersionCode >=  203 /*0302*/ && nVersionCode <= 205 /*0502*/ )        nVersion = TIGER_UA2000;    else if( nVersionCode >=  210 /*1002*/ && nVersionCode <= 306 /*0603*/)        nVersion = TIGER_2002;    else if( nVersionCode >=  312 /*1203*/ && nVersionCode <= 403 /*0304*/)        nVersion = TIGER_2003;    else if( nVersionCode >=  404 )        nVersion = TIGER_2004;    return nVersion;}/************************************************************************//*                         TigerVersionString()                         *//************************************************************************/char * TigerVersionString( TigerVersion nVersion ){  if (nVersion == TIGER_1990_Precensus) { return "TIGER_1990_Precensus"; }  if (nVersion == TIGER_1990) { return "TIGER_1990"; }  if (nVersion == TIGER_1992) { return "TIGER_1992"; }  if (nVersion == TIGER_1994) { return "TIGER_1994"; }  if (nVersion == TIGER_1995) { return "TIGER_1995"; }  if (nVersion == TIGER_1997) { return "TIGER_1997"; }  if (nVersion == TIGER_1998) { return "TIGER_1998"; }  if (nVersion == TIGER_1999) { return "TIGER_1999"; }  if (nVersion == TIGER_2000_Redistricting) { return "TIGER_2000_Redistricting"; }  if (nVersion == TIGER_UA2000) { return "TIGER_UA2000"; }  if (nVersion == TIGER_2002) { return "TIGER_2002"; }  if (nVersion == TIGER_2003) { return "TIGER_2003"; }  if (nVersion == TIGER_2004) { return "TIGER_2004"; }  if (nVersion == TIGER_Unknown) { return "TIGER_Unknown"; }  return "???";}/************************************************************************//*                         TigerCheckVersion()                          *//*                                                                      *//*      Some tiger products seem to be generated with version info      *//*      that doesn't match the tiger specs.  We can sometimes           *//*      recognise the wrongness by checking the record length of        *//*      some well known changing files and adjusting the version        *//*      based on this.                                                  *//************************************************************************/TigerVersion OGRTigerDataSource::TigerCheckVersion( TigerVersion nOldVersion,                                                     const char *pszFilename ){    if( nOldVersion != TIGER_2002 )        return nOldVersion;    char *pszRTCFilename = BuildFilename( pszFilename, "C" );    FILE *fp = VSIFOpen( pszRTCFilename, "rb" );    CPLFree( pszRTCFilename );    if( fp == NULL )        return nOldVersion;        char        szHeader[115];    if( VSIFRead( szHeader, sizeof(szHeader)-1, 1, fp ) < 1 )    {        VSIFClose( fp );        return nOldVersion;    }    VSIFClose( fp );    /* -------------------------------------------------------------------- *//*      Is the record length 112?  If so, it is an older version        *//*      than 2002.                                                      *//* -------------------------------------------------------------------- */    if( szHeader[112] == 10 || szHeader[112] == 13 )    {        CPLDebug( "TIGER", "Forcing version back to UA2000 since RTC records are short." );        return TIGER_UA2000;    }    else        return nOldVersion;}/************************************************************************//*                         OGRTigerDataSource()                         *//************************************************************************/OGRTigerDataSource::OGRTigerDataSource(){    bWriteMode = FALSE;    nLayers = 0;    papoLayers = NULL;    nModules = 0;    papszModules = NULL;    pszName = NULL;    pszPath = NULL;    papszOptions = NULL;    poSpatialRef = new OGRSpatialReference( "GEOGCS[\"NAD83\",DATUM[\"North_American_Datum_1983\",SPHEROID[\"GRS 1980\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"degree\",0.0174532925199433]]" );}/************************************************************************//*                        ~OGRTigerDataSource()                         *//************************************************************************/OGRTigerDataSource::~OGRTigerDataSource(){    int         i;    for( i = 0; i < nLayers; i++ )        delete papoLayers[i];        CPLFree( papoLayers );    CPLFree( pszName );    CPLFree( pszPath );    CSLDestroy( papszOptions );    CSLDestroy( papszModules );    delete poSpatialRef;}/************************************************************************//*                              AddLayer()                              *//************************************************************************/void OGRTigerDataSource::AddLayer( OGRTigerLayer * poNewLayer ){    papoLayers = (OGRTigerLayer **)        CPLRealloc( papoLayers, sizeof(void*) * ++nLayers );        papoLayers[nLayers-1] = poNewLayer;}/************************************************************************//*                              GetLayer()                              *//************************************************************************/OGRLayer *OGRTigerDataSource::GetLayer( int iLayer ){    if( iLayer < 0 || iLayer >= nLayers )        return NULL;    else        return papoLayers[iLayer];}/************************************************************************//*                              GetLayer()                              *//************************************************************************/OGRLayer *OGRTigerDataSource::GetLayer( const char *pszLayerName ){    for( int iLayer = 0; iLayer < nLayers; iLayer++ )    {        if( EQUAL(papoLayers[iLayer]->GetLayerDefn()->GetName(),pszLayerName) )            return papoLayers[iLayer];    }    return NULL;}/************************************************************************//*                           GetLayerCount()                            *//************************************************************************/int OGRTigerDataSource::GetLayerCount(){    return nLayers;}/************************************************************************//*                                Open()                                *//************************************************************************/int OGRTigerDataSource::Open( const char * pszFilename, int bTestOpen,                              char ** papszLimitedFileList ){    VSIStatBuf      stat;    char            **papszFileList = NULL;    int             i;    pszName = CPLStrdup( pszFilename );/* -------------------------------------------------------------------- *//*      Is the given path a directory or a regular file?                *//* -------------------------------------------------------------------- */    if( CPLStat( pszFilename, &stat ) != 0         || (!VSI_ISDIR(stat.st_mode) && !VSI_ISREG(stat.st_mode)) )    {        if( !bTestOpen )            CPLError( CE_Failure, CPLE_AppDefined,                   "%s is neither a file or directory, Tiger access failed.\n",                      pszFilename );        return FALSE;    }    /* -------------------------------------------------------------------- *//*      Build a list of filenames we figure are Tiger files.            *//* -------------------------------------------------------------------- */    if( VSI_ISREG(stat.st_mode) )    {        char       szModule[128];        pszPath = CPLStrdup( CPLGetPath(pszFilename) );        strncpy( szModule, CPLGetFilename(pszFilename), sizeof(szModule)-1 );        szModule[strlen(szModule)-1] = '\0';

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月天丁香久久| 天堂精品中文字幕在线| 日韩三级高清在线| 91精品在线一区二区| 在线免费观看视频一区| 一本色道久久综合狠狠躁的推荐 | 17c精品麻豆一区二区免费| 久久久三级国产网站| 国产精品美女久久久久aⅴ国产馆| 精品88久久久久88久久久 | 国产99久久久国产精品潘金网站| 经典三级一区二区| 国产毛片精品国产一区二区三区| 韩国理伦片一区二区三区在线播放| 国产在线日韩欧美| 99久免费精品视频在线观看| 91网站最新地址| 欧美老女人在线| 精品欧美黑人一区二区三区| 国产欧美一区二区精品性| 中文字幕亚洲在| 亚洲一区二区在线观看视频| 丝袜亚洲另类欧美| 国产精品自拍三区| 色综合色综合色综合| 91精品国产麻豆国产自产在线 | 91精品国产综合久久久久久 | 亚洲视频免费看| 亚洲123区在线观看| 狂野欧美性猛交blacked| 国产91精品欧美| 欧美日韩一区二区三区不卡 | 国产在线一区二区| 91精彩视频在线| 精品国产乱码91久久久久久网站| 中文字幕 久热精品 视频在线| 亚洲激情六月丁香| 精品一区二区三区在线视频| 不卡的电影网站| 日韩一级视频免费观看在线| 欧美激情一区二区三区四区| 日一区二区三区| 一本久道中文字幕精品亚洲嫩| 日韩一级欧美一级| 亚洲欧美视频一区| 国产麻豆精品在线| 91精品国产综合久久久久久久| 国产精品久久久久四虎| 久久精品72免费观看| 欧美色精品在线视频| 国产精品美女视频| 精品一区二区综合| 欧美一区二区三级| 亚洲一区二区在线观看视频| 成人av电影免费在线播放| 欧美zozo另类异族| 午夜视黄欧洲亚洲| 色哟哟精品一区| 欧美国产激情一区二区三区蜜月| 麻豆免费精品视频| 91精品视频网| 婷婷国产在线综合| 欧美三级欧美一级| 亚洲成a人v欧美综合天堂下载 | 青青草91视频| 欧美精品18+| 亚洲va欧美va人人爽| 色噜噜久久综合| 中文字幕一区二区三区四区| 国产成人精品影视| 国产香蕉久久精品综合网| 蜜臀国产一区二区三区在线播放| 6080国产精品一区二区| 亚洲v中文字幕| 3d动漫精品啪啪| 日本欧美一区二区三区乱码| 91精品国产色综合久久久蜜香臀| 亚洲国产成人av网| 3atv一区二区三区| 久草这里只有精品视频| 精品女同一区二区| 国产乱码精品一区二区三区忘忧草| 久久亚洲精品国产精品紫薇| 国产九色精品成人porny| 国产精品午夜春色av| 91首页免费视频| 亚洲午夜国产一区99re久久| 9191成人精品久久| 激情文学综合网| 欧美国产激情一区二区三区蜜月| av电影天堂一区二区在线观看| 亚洲视频香蕉人妖| 欧美日韩成人综合天天影院 | 中文在线一区二区| 91麻豆国产福利精品| 丝袜亚洲精品中文字幕一区| 欧美成人a视频| 成人伦理片在线| 亚洲成人激情av| 久久久99精品久久| 91成人在线精品| 狠狠久久亚洲欧美| 一区二区在线看| 精品国产一区二区在线观看| av一本久道久久综合久久鬼色| 亚洲精品国产高清久久伦理二区| 欧美一区二区在线免费播放| 国产一区二区美女诱惑| 亚洲日穴在线视频| 精品国产一区二区三区久久影院| 97aⅴ精品视频一二三区| 日日夜夜精品免费视频| 国产精品天美传媒沈樵| 欧美精品久久天天躁| 成人免费高清视频在线观看| 天天影视涩香欲综合网 | 欧美美女bb生活片| 成人激情黄色小说| 免费精品视频最新在线| 亚洲欧美激情插 | 精品日韩一区二区| 色综合久久久网| 国产乱对白刺激视频不卡| 亚洲综合小说图片| 欧美国产精品专区| 精品噜噜噜噜久久久久久久久试看| 97久久超碰精品国产| 国产一区91精品张津瑜| 日韩影院精彩在线| 亚洲国产欧美在线| 一区视频在线播放| 国产欧美一区二区精品忘忧草| 欧美一级淫片007| 欧美色精品在线视频| 色综合中文字幕国产 | 欧美一区二区三区人| 91官网在线免费观看| 成人的网站免费观看| 国产99久久久久久免费看农村| 九一九一国产精品| 蜜桃在线一区二区三区| 视频一区二区欧美| 天堂一区二区在线| 丝袜国产日韩另类美女| 午夜欧美在线一二页| 亚洲大型综合色站| 亚洲一区二区在线观看视频| 一区二区三区在线观看网站| 自拍偷拍欧美精品| 亚洲美女在线国产| 亚洲精品高清在线观看| 丁香婷婷综合激情五月色| 国产一区中文字幕| 韩国成人在线视频| 国产精品自在在线| 国产黑丝在线一区二区三区| 国产成人在线视频网站| 成人一级黄色片| 99久久久久久| 色婷婷国产精品| 欧美日韩不卡视频| 欧美一级精品大片| 精品嫩草影院久久| 国产蜜臀97一区二区三区| 国产精品久久久爽爽爽麻豆色哟哟| 国产精品美日韩| 亚洲一区二区三区自拍| 亚洲va韩国va欧美va| 免费的国产精品| 国产黄色成人av| 91电影在线观看| 日韩美女主播在线视频一区二区三区| 91麻豆精品国产91久久久久| 2023国产精品视频| 亚洲免费在线看| 久久99精品网久久| 91丝袜美女网| 3atv一区二区三区| 国产精品不卡一区二区三区| 亚洲一卡二卡三卡四卡| 精品在线观看视频| 在线免费观看日本欧美| 精品裸体舞一区二区三区| 亚洲丝袜自拍清纯另类| 免费国产亚洲视频| 色婷婷狠狠综合| 26uuu国产在线精品一区二区| 1区2区3区国产精品| 老司机精品视频一区二区三区| 高清beeg欧美| 欧美精品精品一区| 亚洲少妇中出一区| 国产一区二区在线观看视频| 在线日韩国产精品| 国产精品午夜春色av| 六月丁香婷婷久久| 在线观看国产一区二区| 国产色综合一区| 亚洲午夜视频在线| 国产成人丝袜美腿|