1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
/******************************************************************************
* $Id: tigeroverunder.cpp 22961 2011-08-20 17:09:59Z rouault $
*
* Project: TIGER/Line Translator
* Purpose: Implements TigerOverUnder, providing access to .RTU files.
* Author: Mark Phillips, mbp@geomtech.com
*
******************************************************************************
* Copyright (c) 2002, Frank Warmerdam, Mark Phillips
*
* 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"
CPL_CVSID("$Id: tigeroverunder.cpp 22961 2011-08-20 17:09:59Z rouault $");
#define FILE_CODE "U"
static const TigerFieldInfo rtU_fields[] = {
// fieldname fmt type OFTType beg end len bDefine bSet bWrite
{ "MODULE", ' ', ' ', OFTString, 0, 0, 8, 1, 0, 0 },
{ "FILE", 'L', 'N', OFTInteger, 6, 10, 5, 1, 1, 1 },
{ "TZID", 'R', 'N', OFTInteger, 11, 20, 10, 1, 1, 1 },
{ "RTSQ", 'R', 'N', OFTInteger, 21, 21, 1, 1, 1, 1 },
{ "TLIDOV1", 'R', 'N', OFTInteger, 22, 31, 10, 1, 1, 1 },
{ "TLIDOV2", 'R', 'N', OFTInteger, 32, 41, 10, 1, 1, 1 },
{ "TLIDUN1", 'R', 'N', OFTInteger, 42, 51, 10, 1, 1, 1 },
{ "TLIDUN2", 'R', 'N', OFTInteger, 52, 61, 10, 1, 1, 1 },
{ "FRLONG", 'R', 'N', OFTInteger, 62, 71, 10, 1, 1, 1 },
{ "FRLAT", 'R', 'N', OFTInteger, 72, 80, 9, 1, 1, 1 },
};
static const TigerRecordInfo rtU_info =
{
rtU_fields,
sizeof(rtU_fields) / sizeof(TigerFieldInfo),
80
};
/************************************************************************/
/* TigerOverUnder() */
/************************************************************************/
TigerOverUnder::TigerOverUnder( OGRTigerDataSource * poDSIn,
const char * pszPrototypeModule ) : TigerPoint(TRUE, &rtU_info, FILE_CODE)
{
poDS = poDSIn;
poFeatureDefn = new OGRFeatureDefn( "OverUnder" );
poFeatureDefn->Reference();
poFeatureDefn->SetGeomType( wkbNone );
AddFieldDefns( psRTInfo, poFeatureDefn );
}
OGRFeature *TigerOverUnder::GetFeature( int nRecordId )
{
return TigerPoint::GetFeature( nRecordId,
62, 71,
72, 80 );
}
OGRErr TigerOverUnder::CreateFeature( OGRFeature *poFeature )
{
return TigerPoint::CreateFeature( poFeature,
62 );
}
|