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

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

?? ogr_miattrind.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************** * $Id: ogr_miattrind.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  OpenGIS Simple Features Reference Implementation * Purpose:  Implements interface to MapInfo .ID files used as attribute *           indexes.   * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 2003, Frank Warmerdam * * 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_attrind.h"#include "mitab/mitab_priv.h"#include "cpl_minixml.h"CPL_CVSID("$Id: ogr_miattrind.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                            OGRMIAttrIndex                            *//*                                                                      *//*      MapInfo .ID implementation of access to one fields              *//*      indexing.                                                       *//************************************************************************/class OGRMILayerAttrIndex;class OGRMIAttrIndex : public OGRAttrIndex{public:    int         iIndex;    TABINDFile  *poINDFile;    OGRMILayerAttrIndex *poLIndex;    OGRFieldDefn *poFldDefn;    int         iField;                OGRMIAttrIndex( OGRMILayerAttrIndex *, int iIndex, int iField);               ~OGRMIAttrIndex();    GByte      *BuildKey( OGRField *psKey );    long        GetFirstMatch( OGRField *psKey );    long       *GetAllMatches( OGRField *psKey );    OGRErr      AddEntry( OGRField *psKey, long nFID );    OGRErr      RemoveEntry( OGRField *psKey, long nFID );    OGRErr      Clear();};/************************************************************************//* ==================================================================== *//*                         OGRMILayerAttrIndex                          *//*                                                                      *//*      MapInfo .ID specific implementation of a layer attribute        *//*      index.                                                          *//* ==================================================================== *//************************************************************************/class OGRMILayerAttrIndex : public OGRLayerAttrIndex{public:    TABINDFile  *poINDFile;    int         nIndexCount;    OGRMIAttrIndex **papoIndexList;    char        *pszMetadataFilename;    char        *pszMIINDFilename;                    OGRMILayerAttrIndex();    virtual     ~OGRMILayerAttrIndex();    /* base class virtual methods */    OGRErr      Initialize( const char *pszIndexPath, OGRLayer * );    OGRErr      CreateIndex( int iField );    OGRErr      DropIndex( int iField );    OGRErr      IndexAllFeatures( int iField = -1 );    OGRErr      AddToIndex( OGRFeature *poFeature, int iField = -1 );    OGRErr      RemoveFromIndex( OGRFeature *poFeature );    OGRAttrIndex *GetFieldIndex( int iField );    /* custom to OGRMILayerAttrIndex */    OGRErr      SaveConfigToXML();    OGRErr      LoadConfigFromXML();    void        AddAttrInd( int iField, int iINDIndex );    OGRLayer   *GetLayer() { return poLayer; }};/************************************************************************//*                        OGRMILayerAttrIndex()                         *//************************************************************************/OGRMILayerAttrIndex::OGRMILayerAttrIndex(){    poINDFile = NULL;    nIndexCount = 0;    papoIndexList = NULL;}/************************************************************************//*                        ~OGRMILayerAttrIndex()                        *//************************************************************************/OGRMILayerAttrIndex::~OGRMILayerAttrIndex(){    if( poINDFile != NULL )    {        poINDFile->Close();        delete poINDFile;        poINDFile = NULL;    }    for( int i = 0; i < nIndexCount; i++ )        delete papoIndexList[i];    CPLFree( papoIndexList );    CPLFree( pszMIINDFilename );    CPLFree( pszMetadataFilename );}/************************************************************************//*                             Initialize()                             *//************************************************************************/OGRErr OGRMILayerAttrIndex::Initialize( const char *pszIndexPathIn,                                         OGRLayer *poLayerIn ){    if( poLayerIn == poLayer )        return OGRERR_NONE;/* -------------------------------------------------------------------- *//*      Capture input information and form static pathnames.            *//* -------------------------------------------------------------------- */    poLayer = poLayerIn;    pszIndexPath = CPLStrdup( pszIndexPathIn );        pszMetadataFilename = CPLStrdup(        CPLResetExtension( pszIndexPathIn, "idm" ) );        pszMIINDFilename = CPLStrdup(CPLResetExtension( pszIndexPathIn, "ind" ));/* -------------------------------------------------------------------- *//*      If a metadata file already exists, load it.                     *//* -------------------------------------------------------------------- */    OGRErr eErr;    VSIStatBuf sStat;    if( VSIStat( pszMetadataFilename, &sStat ) == 0 )    {        eErr = LoadConfigFromXML();        if( eErr != OGRERR_NONE )            return eErr;    }    return OGRERR_NONE;}/************************************************************************//*                         LoadConfigFromXML()                          *//************************************************************************/OGRErr OGRMILayerAttrIndex::LoadConfigFromXML(){    FILE *fp;    int  nXMLSize;    char *pszRawXML;    CPLAssert( poINDFile == NULL );/* -------------------------------------------------------------------- *//*      Read the XML file.                                              *//* -------------------------------------------------------------------- */    fp = VSIFOpen( pszMetadataFilename, "rb" );    if( fp == NULL )        return OGRERR_NONE;    VSIFSeek( fp, 0, SEEK_END );    nXMLSize = VSIFTell( fp );    VSIFSeek( fp, 0, SEEK_SET );    pszRawXML = (char *) CPLMalloc(nXMLSize+1);    pszRawXML[nXMLSize] = '\0';    VSIFRead( pszRawXML, nXMLSize, 1, fp );    VSIFClose( fp );/* -------------------------------------------------------------------- *//*      Parse the XML.                                                  *//* -------------------------------------------------------------------- */    CPLXMLNode *psRoot = CPLParseXMLString( pszRawXML );    CPLFree( pszRawXML );    if( psRoot == NULL )        return OGRERR_FAILURE;/* -------------------------------------------------------------------- *//*      Open the index file.                                            *//* -------------------------------------------------------------------- */    poINDFile = new TABINDFile();    if( poINDFile->Open( pszMetadataFilename, "r+" ) != 0 )    {        CPLDestroyXMLNode( psRoot );        CPLError( CE_Failure, CPLE_OpenFailed,                  "Failed to open index file %s.",                   pszMIINDFilename );        return OGRERR_FAILURE;    }/* -------------------------------------------------------------------- *//*      Process each attrindex.                                         *//* -------------------------------------------------------------------- */    CPLXMLNode *psAttrIndex;    for( psAttrIndex = psRoot->psChild;          psAttrIndex != NULL;          psAttrIndex = psAttrIndex->psNext )    {        int iField, iIndexIndex;        if( psAttrIndex->eType != CXT_Element             || !EQUAL(psAttrIndex->pszValue,"OGRMIAttrIndex") )            continue;        iField = atoi(CPLGetXMLValue(psAttrIndex,"FieldIndex","-1"));        iIndexIndex = atoi(CPLGetXMLValue(psAttrIndex,"IndexIndex","-1"));        if( iField == -1 || iIndexIndex == -1 )        {            CPLError( CE_Warning, CPLE_AppDefined,                       "Skipping corrupt OGRMIAttrIndex entry." );            continue;        }        AddAttrInd( iField, iIndexIndex );    }    CPLDestroyXMLNode( psRoot );    CPLDebug( "OGR", "Restored %d field indexes for layer %s from %s on %s.",              nIndexCount, poLayer->GetLayerDefn()->GetName(),               pszMetadataFilename, pszMIINDFilename );    return OGRERR_NONE;}/************************************************************************//*                          SaveConfigToXML()                           *//************************************************************************/OGRErr OGRMILayerAttrIndex::SaveConfigToXML(){    if( nIndexCount == 0 )        return OGRERR_NONE;/* -------------------------------------------------------------------- *//*      Create the XML tree corresponding to this layer.                *//* -------------------------------------------------------------------- */    CPLXMLNode *psRoot;    psRoot = CPLCreateXMLNode( NULL, CXT_Element, "OGRMILayerAttrIndex" );    CPLCreateXMLElementAndValue( psRoot, "MIIDFilename",                                  CPLGetFilename( pszMIINDFilename ) );        for( int i = 0; i < nIndexCount; i++ )    {        OGRMIAttrIndex *poAI = papoIndexList[i];        CPLXMLNode *psIndex;        psIndex = CPLCreateXMLNode( psRoot, CXT_Element, "OGRMIAttrIndex" );        CPLCreateXMLElementAndValue( psIndex, "FieldIndex",                                      CPLSPrintf( "%d", poAI->iField ) );                                             CPLCreateXMLElementAndValue( psIndex, "FieldName",                                      poLayer->GetLayerDefn()->GetFieldDefn(poAI->iField)->GetNameRef() );                                             CPLCreateXMLElementAndValue( psIndex, "IndexIndex",                                      CPLSPrintf( "%d", poAI->iIndex ) );    }/* -------------------------------------------------------------------- *//*      Save it.                                                        *//* -------------------------------------------------------------------- */    char *pszRawXML = CPLSerializeXMLTree( psRoot );    FILE *fp;    CPLDestroyXMLNode( psRoot );    fp = VSIFOpen( pszMetadataFilename, "wb" );    if( fp == NULL )    {        CPLError( CE_Failure, CPLE_OpenFailed,                   "Failed to pen `%s' for write.",                   pszMetadataFilename );        CPLFree( pszRawXML );        return OGRERR_FAILURE;    }    VSIFWrite( pszRawXML, 1, strlen(pszRawXML), fp );    VSIFClose( fp );    CPLFree( pszRawXML );        return OGRERR_NONE;}/************************************************************************//*                          IndexAllFeatures()                          *//************************************************************************/OGRErr OGRMILayerAttrIndex::IndexAllFeatures( int iField ){    OGRFeature *poFeature;    poLayer->ResetReading();        while( (poFeature = poLayer->GetNextFeature()) != NULL )    {        OGRErr eErr = AddToIndex( poFeature, iField );                delete poFeature;        if( eErr != CE_None )            return eErr;    }    poLayer->ResetReading();    return OGRERR_NONE;}/************************************************************************//*                            CreateIndex()                             *//*                                                                      *//*      Create an index corresponding to the indicated field, but do    *//*      not populate it.  Use IndexAllFeatures() for that.              *//************************************************************************/OGRErr OGRMILayerAttrIndex::CreateIndex( int iField ){/* -------------------------------------------------------------------- *//*      Do we have an open .ID file yet?  If not, create it now.        *//* -------------------------------------------------------------------- */    if( poINDFile == NULL )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品在线电影| 日韩电影免费在线看| 国产传媒日韩欧美成人| 日韩欧美国产不卡| 天堂在线一区二区| 国产91在线|亚洲| 中文字幕第一区| 奇米一区二区三区av| 日韩一级片在线播放| 日韩精品1区2区3区| 日韩精品一区二区在线观看| 日韩黄色一级片| 精品91自产拍在线观看一区| 久久99热这里只有精品| 欧美伦理影视网| 国产精品18久久久久久久久久久久| 欧美一级日韩不卡播放免费| 国产一区不卡精品| 久久精品一区二区三区不卡| 99视频在线观看一区三区| 国产精品久久久久9999吃药| 国产精品伊人色| 亚洲欧美国产毛片在线| 日本高清成人免费播放| 免费观看在线综合| 久久综合九色欧美综合狠狠| eeuss鲁片一区二区三区在线看| 中文字幕一区二区不卡| 日韩成人午夜电影| 国产女人18毛片水真多成人如厕 | 日韩欧美视频在线| 韩国精品主播一区二区在线观看| 国产视频在线观看一区二区三区 | 中文字幕av资源一区| 欧美亚洲国产一卡| 另类的小说在线视频另类成人小视频在线| 欧美精品一区在线观看| 99国产精品久久久久久久久久 | 国产又黄又大久久| 国产精品国产成人国产三级| 成人深夜福利app| 视频一区二区不卡| 精品国产91亚洲一区二区三区婷婷| 99在线精品一区二区三区| 亚洲高清视频在线| 国产精品久久久久一区| 精品视频999| 狠狠色丁香久久婷婷综合_中| 亚洲欧洲精品天堂一级| 欧美日韩亚洲综合一区二区三区| 国产一区二区三区美女| 亚洲伦理在线免费看| 久久你懂得1024| 欧美日韩精品欧美日韩精品一 | 久久免费偷拍视频| 91福利在线导航| 午夜影院久久久| 亚洲天堂免费看| 日韩一区二区免费电影| 色视频一区二区| 国产成人午夜精品影院观看视频| 青青草原综合久久大伊人精品| 中文字幕视频一区| 欧美精品一区二区三区很污很色的| 97精品久久久午夜一区二区三区| 极品少妇一区二区三区精品视频| 亚洲成人av一区二区| 国产精品久久久一区麻豆最新章节| 日韩区在线观看| 在线观看视频一区| 91视频免费看| av网站免费线看精品| www.欧美色图| 国产激情精品久久久第一区二区| 免费成人性网站| 亚洲成人精品一区| 亚洲色图欧洲色图婷婷| 中文字幕一区不卡| 国产亚洲综合性久久久影院| 久久午夜羞羞影院免费观看| 日韩美一区二区三区| 欧美一卡在线观看| 欧美久久一二区| 欧美丰满嫩嫩电影| 欧美三级中文字幕在线观看| 一区二区三区电影在线播| 一区二区三区四区在线| 亚洲日本免费电影| 亚洲一区二区黄色| 亚洲成人免费视| 日本中文字幕不卡| 青青草97国产精品免费观看 | 精品国产乱码久久久久久免费 | 亚洲一区二区三区中文字幕| 最新国产精品久久精品| 日本一区二区综合亚洲| 日韩欧美国产小视频| 国产精品大尺度| 丝袜美腿高跟呻吟高潮一区| 黄色精品一二区| 懂色av中文一区二区三区| 欧美日韩一区二区三区在线看 | 亚洲国产综合色| 久久毛片高清国产| 国产精品高清亚洲| 国产午夜精品在线观看| 日本一区二区成人在线| 国产精品美女久久久久av爽李琼| 国产亚洲精品久| 亚洲免费观看视频| 五月婷婷久久综合| 国产成人午夜高潮毛片| 欧美三级视频在线| www欧美成人18+| 欧美高清性hdvideosex| 国产精品天美传媒沈樵| 午夜精彩视频在线观看不卡| 国内一区二区视频| 久久综合九色综合欧美98| 日本亚洲三级在线| 97久久精品人人澡人人爽| 精品国产一二三区| 全国精品久久少妇| 国产激情一区二区三区| 欧美一区二区二区| 精品不卡在线视频| 国产精品久久久久一区| 天使萌一区二区三区免费观看| 日韩成人午夜精品| 一本高清dvd不卡在线观看| 欧美日韩专区在线| 国产欧美日本一区视频| 一区二区三区精品| 成人免费高清在线| 91论坛在线播放| 免费不卡在线观看| 日韩西西人体444www| 亚洲va天堂va国产va久| 精品视频在线视频| 日韩欧美黄色影院| 亚洲欧美综合另类在线卡通| 国产老妇另类xxxxx| 在线一区二区视频| 亚洲一区在线观看免费| 日韩欧美在线综合网| 免费三级欧美电影| 91.xcao| 亚洲精品国产高清久久伦理二区| 99视频在线观看一区三区| 91精品欧美一区二区三区综合在 | 亚洲最大成人综合| 理论电影国产精品| 欧美日韩国产综合久久| 国产精品久久久爽爽爽麻豆色哟哟| 美女爽到高潮91| 欧美午夜寂寞影院| 亚洲黄色免费网站| 国产iv一区二区三区| 91免费版在线| 亚洲欧洲精品成人久久奇米网| 久久成人精品无人区| 日韩欧美卡一卡二| 亚洲电影视频在线| 欧美中文字幕不卡| 最新不卡av在线| 成+人+亚洲+综合天堂| 久久久久久9999| 国产伦精一区二区三区| 日韩欧美中文一区二区| 日本欧美一区二区在线观看| 国产成人av电影免费在线观看| 久久久国产精华| 捆绑调教一区二区三区| 日韩一区二区高清| 亚洲一区二区美女| 一本大道久久精品懂色aⅴ| 国产女人aaa级久久久级| 国产精品77777| 久久久久久久久久久久电影 | 国产成人综合在线| 久久精品亚洲一区二区三区浴池| 久久99精品一区二区三区| 色婷婷av一区二区三区大白胸| 中国色在线观看另类| 懂色av中文字幕一区二区三区| 国产婷婷色一区二区三区在线| 青青草97国产精品免费观看 | 久久综合狠狠综合久久综合88| 亚洲一二三四区不卡| 色婷婷一区二区| 亚洲黄色av一区| 欧美三级电影一区| 蜜臀av一级做a爰片久久| 日韩精品中文字幕一区 | 黄色资源网久久资源365| 国产精品日日摸夜夜摸av| 成人精品一区二区三区中文字幕| 亚洲欧美欧美一区二区三区| 色综合久久久久综合体桃花网| 亚洲国产成人av网|