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

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

?? mitab_indfile.cpp

?? mitab,讀取MapInfo的地圖文件
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/**********************************************************************
 * $Id: mitab_indfile.cpp,v 1.13 2008/01/29 20:46:32 dmorissette Exp $
 *
 * Name:     mitab_indfile.cpp
 * Project:  MapInfo TAB Read/Write library
 * Language: C++
 * Purpose:  Implementation of the TABINDFile class used to handle
 *           access to .IND file (table field indexes) attached to a .DAT file
 * Author:   Daniel Morissette, dmorissette@dmsolutions.ca
 *
 **********************************************************************
 * Copyright (c) 1999-2001, Daniel Morissette
 *
 * 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.
 **********************************************************************
 *
 * $Log: mitab_indfile.cpp,v $
 * Revision 1.13  2008/01/29 20:46:32  dmorissette
 * Added support for v9 Time and DateTime fields (byg 1754)
 *
 * Revision 1.12  2007/12/11 03:43:03  dmorissette
 * Added reporting access mode to error message in TABINDFile::Open()
 * (GDAL changeset r12460, ticket 1620)
 *
 * Revision 1.11  2005/04/29 19:08:56  dmorissette
 * Produce an error if m_nSubtreeDepth > 255 when creating a .IND (OGR bug 839)
 *
 * Revision 1.10  2004/06/30 20:29:04  dmorissette
 * Fixed refs to old address danmo@videotron.ca
 *
 * Revision 1.9  2003/07/24 02:45:57  daniel
 * Fixed problem scanning node in TABINDNode::FindNext() - bug 2176, FW
 *
 * Revision 1.8  2001/05/01 03:38:23  daniel
 * Added update support (allows creating new index in existing IND files).
 *
 * Revision 1.7  2000/11/13 22:17:57  daniel
 * When a (child) node's first entry is replaced by InsertEntry() then make
 * sure that node's key is updated in its parent node.
 *
 * Revision 1.6  2000/03/01 00:32:00  daniel
 * Added support for float keys, and completed support for generating indexes
 *
 * Revision 1.5  2000/02/28 16:57:42  daniel
 * Added support for writing indexes
 *
 * Revision 1.4  2000/01/15 22:30:44  daniel
 * Switch to MIT/X-Consortium OpenSource license
 *
 * Revision 1.3  1999/12/14 05:52:05  daniel
 * Fixed compile error on Windows
 *
 * Revision 1.2  1999/12/14 02:19:42  daniel
 * Completed .IND support for simple TABViews
 *
 * Revision 1.1  1999/11/20 15:49:07  daniel
 * Initial version
 *
 **********************************************************************/

#include "mitab.h"
#include "mitab_utils.h"

#include <ctype.h>      /* toupper() */

/*=====================================================================
 *                      class TABINDFile
 *====================================================================*/

#define IND_MAGIC_COOKIE  24242424

/**********************************************************************
 *                   TABINDFile::TABINDFile()
 *
 * Constructor.
 **********************************************************************/
TABINDFile::TABINDFile()
{
    m_fp = NULL;
    m_pszFname = NULL;
    m_eAccessMode = TABRead;
    m_numIndexes = 0;
    m_papoIndexRootNodes = NULL;
    m_papbyKeyBuffers = NULL;
}

/**********************************************************************
 *                   TABINDFile::~TABINDFile()
 *
 * Destructor.
 **********************************************************************/
TABINDFile::~TABINDFile()
{
    Close();
}

/**********************************************************************
 *                   TABINDFile::Open()
 *
 * Open a .IND file, read the header and the root nodes for all the
 * field indexes, and be ready to search the indexes.
 *
 * If the filename that is passed in contains a .DAT extension then
 * the extension will be changed to .IND before trying to open the file.
 *
 * Note that we pass a pszAccess flag, but only read access is supported
 * for now (and there are no plans to support write.)
 *
 * Set bTestOpenNoError=TRUE to silently return -1 with no error message
 * if the file cannot be opened because it does not exist.
 *
 * Returns 0 on success, -1 on error.
 **********************************************************************/
int TABINDFile::Open(const char *pszFname, const char *pszAccess,
                     GBool bTestOpenNoError /*=FALSE*/)
{
    int         nLen;

    if (m_fp)
    {
        CPLError(CE_Failure, CPLE_FileIO,
                 "Open() failed: object already contains an open file");
        return -1;
    }

    /*-----------------------------------------------------------------
     * Validate access mode and make sure we use binary access.
     * Note that for write access, we actually need read/write access to
     * the file.
     *----------------------------------------------------------------*/
    if (EQUALN(pszAccess, "r", 1) && strchr(pszAccess, '+') != NULL)
    {
        m_eAccessMode = TABReadWrite;
        pszAccess = "rb+";
    }
    else if (EQUALN(pszAccess, "r", 1))
    {
        m_eAccessMode = TABRead;
        pszAccess = "rb";
    }
    else if (EQUALN(pszAccess, "w", 1))
    {
        m_eAccessMode = TABWrite;
        pszAccess = "wb+";
    }
    else
    {
        CPLError(CE_Failure, CPLE_FileIO,
                 "Open() failed: access mode \"%s\" not supported", pszAccess);
        return -1;
    }

    /*-----------------------------------------------------------------
     * Change .DAT (or .TAB) extension to .IND if necessary
     *----------------------------------------------------------------*/
    m_pszFname = CPLStrdup(pszFname);

    nLen = strlen(m_pszFname);
    if (nLen > 4 && !EQUAL(m_pszFname+nLen-4, ".IND") )
        strcpy(m_pszFname+nLen-4, ".ind");

#ifndef _WIN32
    TABAdjustFilenameExtension(m_pszFname);
#endif

    /*-----------------------------------------------------------------
     * Open file
     *----------------------------------------------------------------*/
    m_fp = VSIFOpen(m_pszFname, pszAccess);

    if (m_fp == NULL)
    {
        if (!bTestOpenNoError)
            CPLError(CE_Failure, CPLE_FileIO,
                     "Open() failed for %s (%s)", m_pszFname, pszAccess);

        CPLFree(m_pszFname);
        m_pszFname = NULL;
        return -1;
    }

    /*-----------------------------------------------------------------
     * Reset block manager to allocate first block at byte 512, after header.
     *----------------------------------------------------------------*/
    m_oBlockManager.Reset();
    m_oBlockManager.AllocNewBlock();

    /*-----------------------------------------------------------------
     * Read access: Read the header block
     * This will also alloc and init the array of index root nodes.
     *----------------------------------------------------------------*/
    if ((m_eAccessMode == TABRead || m_eAccessMode == TABReadWrite) &&
        ReadHeader() != 0)
    {
        // Failed reading header... CPLError() has already been called
        Close();
        return -1;
    }

    /*-----------------------------------------------------------------
     * Write access: Init class members and write a dummy header block
     *----------------------------------------------------------------*/
    if (m_eAccessMode == TABWrite)
    {
        m_numIndexes = 0;

        if (WriteHeader() != 0)
        {
            // Failed writing header... CPLError() has already been called
            Close();
            return -1;
        }
    }

    return 0;
}

/**********************************************************************
 *                   TABINDFile::Close()
 *
 * Close current file, and release all memory used.
 *
 * Returns 0 on success, -1 on error.
 **********************************************************************/
int TABINDFile::Close()
{
    if (m_fp == NULL)
        return 0;

    /*-----------------------------------------------------------------
     * In Write Mode, commit all indexes to the file
     *----------------------------------------------------------------*/
    if (m_eAccessMode == TABWrite || m_eAccessMode == TABReadWrite)
    {
        WriteHeader();

        for(int iIndex=0; iIndex<m_numIndexes; iIndex++)
        {
            if (m_papoIndexRootNodes &&
                m_papoIndexRootNodes[iIndex])
            {
                m_papoIndexRootNodes[iIndex]->CommitToFile();
            }
        }
    }

    /*-----------------------------------------------------------------
     * Free index nodes in memory
     *----------------------------------------------------------------*/
    for (int iIndex=0; iIndex<m_numIndexes; iIndex++)
    {
        if (m_papoIndexRootNodes && m_papoIndexRootNodes[iIndex])
            delete m_papoIndexRootNodes[iIndex];
        if (m_papbyKeyBuffers && m_papbyKeyBuffers[iIndex])
            CPLFree(m_papbyKeyBuffers[iIndex]);
    }
    CPLFree(m_papoIndexRootNodes);
    m_papoIndexRootNodes = NULL;
    CPLFree(m_papbyKeyBuffers);
    m_papbyKeyBuffers = NULL;
    m_numIndexes = 0;

    /*-----------------------------------------------------------------
     * Close file
     *----------------------------------------------------------------*/
    VSIFClose(m_fp);
    m_fp = NULL;

    CPLFree(m_pszFname);
    m_pszFname = NULL;

    return 0;
}


/**********************************************************************
 *                   TABINDFile::ReadHeader()
 *
 * (private method)
 * Read the header block and init all class members for read access.
 *
 * Returns 0 on success, -1 on error.
 **********************************************************************/
int TABINDFile::ReadHeader()
{

    CPLAssert(m_fp);
    CPLAssert(m_eAccessMode == TABRead || m_eAccessMode == TABReadWrite);

    /*-----------------------------------------------------------------
     * In ReadWrite mode, we need to init BlockManager with file size
     *----------------------------------------------------------------*/
    VSIStatBuf  sStatBuf;
    if (m_eAccessMode == TABReadWrite && VSIStat(m_pszFname, &sStatBuf) != -1)
    {
        m_oBlockManager.SetLastPtr(((sStatBuf.st_size-1)/512)*512);
    }

    /*-----------------------------------------------------------------
     * Read the header block
     *----------------------------------------------------------------*/
    TABRawBinBlock *poHeaderBlock;
    poHeaderBlock = new TABRawBinBlock(m_eAccessMode, TRUE);
    if (poHeaderBlock->ReadFromFile(m_fp, 0, 512) != 0)
    {
        // CPLError() has already been called.
        delete poHeaderBlock;
        return -1;
    }

    poHeaderBlock->GotoByteInBlock(0);
    GUInt32 nMagicCookie = poHeaderBlock->ReadInt32();
    if (nMagicCookie != IND_MAGIC_COOKIE)
    {
        CPLError(CE_Failure, CPLE_FileIO,
                 "%s: Invalid Magic Cookie: got %d, expected %d",
                 m_pszFname, nMagicCookie, IND_MAGIC_COOKIE);
        delete poHeaderBlock;
        return -1;
    }

    poHeaderBlock->GotoByteInBlock(12);
    m_numIndexes = poHeaderBlock->ReadInt16();
    if (m_numIndexes < 1 || m_numIndexes > 29)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产乱码精品一品二品| 成人一区在线观看| 欧美激情一区二区三区不卡 | 91精品国产综合久久久久| 精品免费国产一区二区三区四区| www久久精品| 欧美亚洲综合色| 91精品国产aⅴ一区二区| 91精品国产美女浴室洗澡无遮挡| 日韩一级大片在线观看| 国产精品国产三级国产专播品爱网 | 午夜久久久影院| 午夜视频久久久久久| 国内成人免费视频| 欧美在线影院一区二区| 欧美激情一区二区在线| 亚洲va在线va天堂| 成人av动漫网站| 亚洲天堂久久久久久久| 精品一区二区三区在线视频| 国产伦精品一区二区三区免费迷 | 激情图片小说一区| 欧美日韩亚洲综合一区二区三区| 国产欧美一区二区精品性色超碰| 亚洲一二三四在线| 色婷婷综合激情| 日韩av在线发布| 天天综合日日夜夜精品| 一区二区三区产品免费精品久久75| 国产美女在线精品| 精品精品国产高清a毛片牛牛 | 99国产精品久久久久久久久久久| 日韩欧美黄色影院| 午夜久久久久久电影| k8久久久一区二区三区| 一区二区三区在线视频观看| 色老汉一区二区三区| 一区二区三区国产豹纹内裤在线| 成人不卡免费av| 丝袜美腿亚洲综合| 亚洲日本韩国一区| 专区另类欧美日韩| 国产永久精品大片wwwapp| 2021国产精品久久精品| 国产成人综合精品三级| 亚洲精品水蜜桃| 欧美伦理影视网| 成人动漫一区二区| 国产一区二区三区日韩| 亚洲国产日韩a在线播放性色| 中文字幕第一区综合| 国产亚洲综合av| 亚洲高清不卡在线观看| 日本一区二区免费在线观看视频| 欧洲激情一区二区| 成人精品电影在线观看| 亚洲va欧美va人人爽午夜 | 青青草一区二区三区| 色婷婷久久久综合中文字幕| 日本一区二区三区dvd视频在线| 欧美日韩夫妻久久| 成人精品国产免费网站| 国产91综合一区在线观看| 日本aⅴ免费视频一区二区三区| 亚洲尤物在线视频观看| 婷婷久久综合九色国产成人| 久久久国产精品午夜一区ai换脸| 国产欧美精品在线观看| 欧美一区二区三区在线电影| 欧美色偷偷大香| 欧美日韩一区精品| 日韩欧美亚洲另类制服综合在线| 欧美电影免费观看高清完整版在线观看 | 欧美一级理论片| 久久99精品国产.久久久久久| 男女性色大片免费观看一区二区| 青青草国产精品97视觉盛宴| 奇米在线7777在线精品| 日本不卡在线视频| 懂色中文一区二区在线播放| 成人av电影在线观看| 白白色亚洲国产精品| 国产精品久久久爽爽爽麻豆色哟哟| 国产69精品一区二区亚洲孕妇| 国模套图日韩精品一区二区| 99精品欧美一区二区三区综合在线| www..com久久爱| 日韩一级完整毛片| 亚洲一区二区三区四区在线| 国产资源精品在线观看| 大桥未久av一区二区三区中文| 日韩av电影一区| 亚洲国产精品久久人人爱蜜臀| 亚洲一区二区三区小说| 国产成人av一区二区三区在线观看| 欧美网站一区二区| 亚洲免费在线看| 欧美中文字幕一区二区三区亚洲| 久久免费国产精品| 国产寡妇亲子伦一区二区| 国产欧美精品区一区二区三区| 国产精品18久久久久久久网站| 麻豆精品一二三| 在线视频亚洲一区| 国产精品第四页| 97精品电影院| 亚洲一区二区在线观看视频 | 99久久精品国产一区二区三区| 在线观看视频91| 国产精品小仙女| 国内成+人亚洲+欧美+综合在线| 久久99久久99小草精品免视看| 91蜜桃传媒精品久久久一区二区| 欧美一区二区三区在线电影| 国产风韵犹存在线视精品| 中文字幕一区二区三区不卡在线| 成人动漫一区二区| 精品综合久久久久久8888| 亚洲天天做日日做天天谢日日欢| 91精品国产一区二区三区 | 欧美日韩国产精选| 99久久国产综合色|国产精品| 麻豆极品一区二区三区| 午夜欧美视频在线观看| 亚洲一区二区在线视频| 一区二区三区免费观看| 亚洲精品日韩综合观看成人91| 久久精品欧美一区二区三区不卡| 日韩欧美资源站| 久久一留热品黄| 2021久久国产精品不只是精品| 欧洲av一区二区嗯嗯嗯啊| 成人精品鲁一区一区二区| 国产一区二区毛片| 成人免费高清在线观看| 国产suv精品一区二区883| 国产不卡免费视频| 色偷偷久久人人79超碰人人澡| 色综合欧美在线视频区| 91国模大尺度私拍在线视频| 在线成人av影院| 久久精品水蜜桃av综合天堂| 国产精品麻豆视频| 奇米精品一区二区三区四区 | 成人丝袜18视频在线观看| gogogo免费视频观看亚洲一| 色婷婷综合久色| 国产欧美一区二区三区网站 | 久久97超碰国产精品超碰| 国产精品久久综合| 久久久www成人免费无遮挡大片| 欧美日韩一区不卡| 欧美精品 日韩| 欧美一级搡bbbb搡bbbb| 欧美日韩国产精选| 日韩限制级电影在线观看| 日韩欧美另类在线| 日韩三级视频在线看| 欧美日韩高清一区二区不卡 | 精品国产污污免费网站入口| 欧美性极品少妇| 中文字幕在线不卡视频| heyzo一本久久综合| 国产精品久久久久久妇女6080| 国产不卡在线一区| 国产精品久久久久久久久免费樱桃| 成人午夜碰碰视频| 亚洲一区国产视频| 精品久久久久一区二区国产| 午夜精品久久久久久久久久久| 欧美日韩1234| 久久国产精品露脸对白| 色婷婷香蕉在线一区二区| 欧美一级黄色片| 日本不卡123| 欧美日本韩国一区| 夜夜亚洲天天久久| 色乱码一区二区三区88| 国产精品美女久久久久久| 国产精品1区2区| 亚洲欧洲日韩女同| 欧美性xxxxx极品少妇| 国产精品伦理在线| 97精品久久久久中文字幕| 国产免费观看久久| 91美女在线看| 香蕉成人伊视频在线观看| 91精品国产入口在线| 国产精品影视天天线| 国产精品九色蝌蚪自拍| 日本道免费精品一区二区三区| 亚洲图片自拍偷拍| 精品国产精品网麻豆系列| 成人午夜免费电影| 亚瑟在线精品视频| 欧美mv日韩mv| 91久久线看在观草草青青| 免费观看30秒视频久久| 国产视频一区不卡| 678五月天丁香亚洲综合网|