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

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

?? ogrfeaturequery.cpp

?? mitab,讀取MapInfo的地圖文件
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
 * $Id: ogrfeaturequery.cpp 11207 2007-04-04 17:02:36Z warmerdam $
 * 
 * Project:  OpenGIS Simple Features Reference Implementation
 * Purpose:  Implementation of simple SQL WHERE style attributes queries
 *           for OGRFeatures.  
 * Author:   Frank Warmerdam, warmerdam@pobox.com
 *
 ******************************************************************************
 * Copyright (c) 2001, 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 <assert.h>
#include "ogr_feature.h"
#include "ogr_p.h"
#include "ogr_attrind.h"

CPL_CVSID("$Id: ogrfeaturequery.cpp 11207 2007-04-04 17:02:36Z warmerdam $");

/************************************************************************/
/*     Support for special attributes (feature query and selection)     */
/************************************************************************/

char* SpecialFieldNames[SPECIAL_FIELD_COUNT] 
    = {"FID", "OGR_GEOMETRY", "OGR_STYLE", "OGR_GEOM_WKT"};
swq_field_type SpecialFieldTypes[SPECIAL_FIELD_COUNT] 
    = {SWQ_INTEGER, SWQ_STRING, SWQ_STRING, SWQ_STRING};

/************************************************************************/
/*                          OGRFeatureQuery()                           */
/************************************************************************/

OGRFeatureQuery::OGRFeatureQuery()

{
    poTargetDefn = NULL;
    pSWQExpr = NULL;
}

/************************************************************************/
/*                          ~OGRFeatureQuery()                          */
/************************************************************************/

OGRFeatureQuery::~OGRFeatureQuery()

{
    if( pSWQExpr != NULL )
        swq_expr_free( (swq_expr *) pSWQExpr );
}

/************************************************************************/
/*                                Parse                                 */
/************************************************************************/

OGRErr OGRFeatureQuery::Compile( OGRFeatureDefn *poDefn, 
                                 const char * pszExpression )

{
/* -------------------------------------------------------------------- */
/*      Clear any existing expression.                                  */
/* -------------------------------------------------------------------- */
    if( pSWQExpr != NULL )
        swq_expr_free( (swq_expr *) pSWQExpr );

/* -------------------------------------------------------------------- */
/*      Build list of fields.                                           */
/* -------------------------------------------------------------------- */
    char        **papszFieldNames;
    swq_field_type *paeFieldTypes;
    int         iField;
    int         nFieldCount = poDefn->GetFieldCount() + SPECIAL_FIELD_COUNT;

    papszFieldNames = (char **) 
        CPLMalloc(sizeof(char *) * nFieldCount );
    paeFieldTypes = (swq_field_type *) 
        CPLMalloc(sizeof(swq_field_type) * nFieldCount );

    for( iField = 0; iField < poDefn->GetFieldCount(); iField++ )
    {
        OGRFieldDefn    *poField = poDefn->GetFieldDefn( iField );

        papszFieldNames[iField] = (char *) poField->GetNameRef();

        switch( poField->GetType() )
        {
          case OFTInteger:
            paeFieldTypes[iField] = SWQ_INTEGER;
            break;

          case OFTReal:
            paeFieldTypes[iField] = SWQ_FLOAT;
            break;

          case OFTString:
            paeFieldTypes[iField] = SWQ_STRING;
            break;

          default:
            paeFieldTypes[iField] = SWQ_OTHER;
            break;
        }
    }

    iField = 0;
    while (iField < SPECIAL_FIELD_COUNT)
    {
        papszFieldNames[poDefn->GetFieldCount() + iField] = SpecialFieldNames[iField];
        paeFieldTypes[poDefn->GetFieldCount() + iField] = SpecialFieldTypes[iField];
        ++iField;
    }

/* -------------------------------------------------------------------- */
/*      Try to parse.                                                   */
/* -------------------------------------------------------------------- */
    const char  *pszError;
    OGRErr      eErr = OGRERR_NONE;

    poTargetDefn = poDefn;
    pszError = swq_expr_compile( pszExpression, nFieldCount,
                                 papszFieldNames, paeFieldTypes, 
                                 (swq_expr **) &pSWQExpr );
    if( pszError != NULL )
    {
        CPLError( CE_Failure, CPLE_AppDefined, 
                  "%s", pszError );
        eErr = OGRERR_CORRUPT_DATA;
        pSWQExpr = NULL;
    }

    CPLFree( papszFieldNames );
    CPLFree( paeFieldTypes );


    return eErr;
}

/************************************************************************/
/*                      OGRFeatureQueryEvaluator()                      */
/************************************************************************/

static int OGRFeatureQueryEvaluator( swq_field_op *op, OGRFeature *poFeature )

{
    OGRField sField;
    OGRField *psField;

    int iSpecialField = op->field_index - poFeature->GetDefnRef()->GetFieldCount();
    if( iSpecialField >= 0 )
    {
        if ( iSpecialField < SPECIAL_FIELD_COUNT )
        {
            switch ( SpecialFieldTypes[iSpecialField] )
            {
              case SWQ_INTEGER:
                sField.Integer = poFeature->GetFieldAsInteger(op->field_index);
                break;
                
              case SWQ_STRING:
                sField.String = (char*) 
                    poFeature->GetFieldAsString( op->field_index );
                break;
            }      
        }
        else
        {
            CPLDebug( "OGRFeatureQuery", "Illegal special field index.");
            return FALSE;
        }
        psField = &sField;
    }
    else
        psField = poFeature->GetRawFieldRef( op->field_index );

    switch( op->field_type )
    {
      case SWQ_INTEGER:
        switch( op->operation )
        {
          case SWQ_EQ:
            return psField->Integer == op->int_value;
          case SWQ_NE:
            return psField->Integer != op->int_value;
          case SWQ_LT:
            return psField->Integer < op->int_value;
          case SWQ_GT:
            return psField->Integer > op->int_value;
          case SWQ_LE:
            return psField->Integer <= op->int_value;
          case SWQ_GE:
            return psField->Integer >= op->int_value;
          case SWQ_ISNULL:
            return !poFeature->IsFieldSet( op->field_index );

          case SWQ_IN:
          {
              const char *pszSrc;
              
              pszSrc = op->string_value;
              while( *pszSrc != '\0' )
              {
                  if( atoi(pszSrc) == psField->Integer )
                      return TRUE;
                  pszSrc += strlen(pszSrc) + 1;
              }

              return FALSE;
          }

          default:
            CPLDebug( "OGRFeatureQuery", 
                      "Illegal operation (%d) on integer field.",
                      op->operation );
            return FALSE;
        }

      case SWQ_FLOAT:
        switch( op->operation )
        {
          case SWQ_EQ:
            return psField->Real == op->float_value;
          case SWQ_NE:
            return psField->Real != op->float_value;
          case SWQ_LT:
            return psField->Real < op->float_value;
          case SWQ_GT:
            return psField->Real > op->float_value;
          case SWQ_LE:
            return psField->Real <= op->float_value;
          case SWQ_GE:
            return psField->Real >= op->float_value;
          case SWQ_ISNULL:
            return !poFeature->IsFieldSet( op->field_index );
          case SWQ_IN:
          {
              const char *pszSrc;
              
              pszSrc = op->string_value;
              while( *pszSrc != '\0' )
              {
                  if( atof(pszSrc) == psField->Real )
                      return TRUE;
                  pszSrc += strlen(pszSrc) + 1;
              }

              return FALSE;
          }

          default:
            CPLDebug( "OGRFeatureQuery", 
                      "Illegal operation (%d) on float field.",
                      op->operation );
            return FALSE;
        }

      case SWQ_STRING:
        switch( op->operation )
        {
          case SWQ_EQ:
            if (psField->Set.nMarker1 == OGRUnsetMarker
                && psField->Set.nMarker2 == OGRUnsetMarker )
            {
                return (op->string_value[0] == '\0');
            }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男人天堂一区| 国产性天天综合网| 欧美一级xxx| 亚洲婷婷国产精品电影人久久| 亚洲高清久久久| 成人免费毛片嘿嘿连载视频| 欧美一区二区三区在线视频| 亚洲男人的天堂网| 国产在线精品免费| 欧美日韩一级二级三级| 中文字幕亚洲不卡| 国产精品一区二区在线观看网站| 欧美一级一级性生活免费录像| 亚洲欧美一区二区三区久本道91| av一区二区久久| 666欧美在线视频| 亚洲女爱视频在线| 高清不卡在线观看av| 日韩一区二区三区电影在线观看 | 国产一区二区三区综合| 欧美三级日韩三级| 一区二区三区在线播放| 99久久国产免费看| 国产日韩精品一区二区三区在线| 国产一区二区免费视频| 日韩欧美综合在线| 视频一区二区国产| 欧美精品亚洲二区| 亚洲成人av电影| 在线观看一区二区视频| 一区二区三区中文字幕精品精品| 国产精品羞羞答答xxdd| 6080yy午夜一二三区久久| 亚洲女性喷水在线观看一区| 91美女片黄在线观看91美女| 成人欧美一区二区三区小说 | 免费xxxx性欧美18vr| 欧美日本一区二区在线观看| 亚洲成av人在线观看| 欧美日产国产精品| 天天色综合成人网| 欧美另类z0zxhd电影| 免费在线看一区| 337p粉嫩大胆色噜噜噜噜亚洲| 国产主播一区二区三区| 久久精品亚洲国产奇米99| 国产盗摄一区二区| 亚洲日本护士毛茸茸| 中文字幕av免费专区久久| 青青青爽久久午夜综合久久午夜| 91精品欧美综合在线观看最新| 激情五月婷婷综合| 国产丝袜欧美中文另类| 99久久国产综合精品色伊| 亚洲精品中文字幕在线观看| 欧美肥妇bbw| 国产福利91精品一区| 亚洲人被黑人高潮完整版| 欧美精品久久一区| 国内精品在线播放| 亚洲图片欧美激情| 日韩一区二区不卡| 国产 欧美在线| 亚洲成av人片一区二区梦乃| 欧美电视剧免费全集观看| 成人午夜精品在线| 偷拍日韩校园综合在线| 国产日产欧美一区二区三区| 精品视频在线免费| 国产91色综合久久免费分享| 亚洲综合成人在线| 久久久亚洲精品一区二区三区| 色综合色狠狠综合色| 蜜芽一区二区三区| 综合久久综合久久| 91精品国产日韩91久久久久久| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 精品一区二区国语对白| 亚洲视频电影在线| 久久中文娱乐网| 欧美日韩在线直播| 成人免费视频视频在线观看免费 | 91免费看片在线观看| 久久99蜜桃精品| 亚洲观看高清完整版在线观看 | 成人少妇影院yyyy| 日韩和欧美一区二区| 亚洲人成人一区二区在线观看| 欧美精品一区二区三区四区 | 色综合久久久久综合99| 黄色日韩三级电影| 亚洲国产欧美一区二区三区丁香婷| 国产日产欧美一区二区三区| 欧美sm极限捆绑bd| 6080国产精品一区二区| 在线观看日韩精品| eeuss影院一区二区三区| 国产麻豆精品久久一二三| 日韩av不卡一区二区| 亚洲动漫第一页| 亚洲国产sm捆绑调教视频| 《视频一区视频二区| 国产欧美日韩综合精品一区二区| 日韩你懂的在线观看| 欧美日韩国产大片| 欧美亚洲综合一区| 91成人在线免费观看| 97se亚洲国产综合在线| 99久久婷婷国产| 成人av免费在线播放| 成人av网址在线| va亚洲va日韩不卡在线观看| 成人夜色视频网站在线观看| 国产精品性做久久久久久| 国产不卡视频在线播放| 国产精品一区二区91| 国产一区二区三区美女| 国产制服丝袜一区| 国产呦萝稀缺另类资源| 国产一区二区三区不卡在线观看 | 91麻豆精品国产无毒不卡在线观看| 欧美日韩精品一区二区天天拍小说| 在线观看精品一区| 欧美精选在线播放| 欧美精品精品一区| 日韩欧美一区在线观看| 精品国产亚洲一区二区三区在线观看| 欧美r级在线观看| 国产亚洲欧美在线| 国产精品福利一区| 一区二区三区在线播| 一区二区不卡在线视频 午夜欧美不卡在 | 日韩免费观看高清完整版在线观看| 91精品欧美久久久久久动漫| 精品日韩在线观看| 国产日韩欧美麻豆| 国产精品不卡视频| 亚洲一区二区黄色| 亚洲国产毛片aaaaa无费看 | 色一区在线观看| 在线综合视频播放| 久久先锋影音av鲁色资源网| 国产精品麻豆网站| 亚洲午夜精品网| 久久精品国内一区二区三区| 粉嫩在线一区二区三区视频| 日本高清不卡一区| 26uuu国产电影一区二区| 亚洲欧洲日产国码二区| 婷婷开心久久网| 高清成人免费视频| 欧美日韩久久一区二区| 国产午夜精品一区二区三区视频| 亚洲女子a中天字幕| 美女在线观看视频一区二区| 99国产精品久久久久| 欧美色图在线观看| 26uuu亚洲| 亚洲妇熟xx妇色黄| 成人美女在线观看| 欧美精品tushy高清| 国产精品美女视频| 午夜电影一区二区三区| 国产91精品精华液一区二区三区 | av一区二区久久| 欧美一区二区三区视频在线 | 欧美日韩国产一区| 精品久久久久久久久久久久久久久 | 精品污污网站免费看| 国产日产精品1区| 丝袜美腿一区二区三区| 91婷婷韩国欧美一区二区| 久久亚洲私人国产精品va媚药| 伊人开心综合网| 7777精品伊人久久久大香线蕉超级流畅| 成人三级在线视频| 欧美猛男gaygay网站| 国产欧美日韩中文久久| 天天射综合影视| 欧美日韩一区三区四区| 国产精品久久久久一区二区三区 | 奇米777欧美一区二区| a级高清视频欧美日韩| 2023国产精品| 美腿丝袜亚洲三区| 久久久久久久久久久久电影 | 99久久免费精品高清特色大片| 久久亚洲二区三区| 免费一区二区视频| 欧美日韩国产高清一区二区三区 | 亚洲伦理在线免费看| 成人av资源站| 国产精品美女久久久久久2018| 国产福利视频一区二区三区| wwwwww.欧美系列| 久久99精品国产麻豆不卡| 制服丝袜激情欧洲亚洲| 亚洲大片在线观看| 欧美日韩卡一卡二| 日韩精品每日更新|