#include "names.hxx"
-// return the type of the shapefile record
-AreaType get_area_type(GDBFile *dbf, int rec) {
- GDBFieldDesc *fdesc[128]; // 128 is an arbitrary number here
- GDBFValue *fields; //an array of field values
- char* dbf_rec; //a record containing all the fields
-
- // grab the meta-information for all the fields
- // this applies to all the records in the DBF file.
- // for ( int i = 0; i < dbf->numFields(); i++ ) {
- // fdesc[i] = dbf->getFieldDesc(i);
- // cout << i << ") " << fdesc[i]->name << endl;
- // }
-
- // this is the whole name record
- dbf_rec = dbf->getRecord( rec );
-
- // parse it into individual fields
- if ( dbf_rec ) {
- fields = dbf->recordDeform( dbf_rec );
- }
-
- string area = fields[4].str_v;
- // strip leading spaces
- while ( area[0] == ' ' ) {
- area = area.substr(1, area.length() - 1);
- }
- // strip trailing spaces
- while ( area[area.length() - 1] == ' ' ) {
- area = area.substr(0, area.length() - 1);
- }
- // strip other junk encountered
- while ( (int)area[area.length() - 1] == 9 ) {
- area = area.substr(0, area.length() - 1);
- }
-
+// return area type from text name
+AreaType get_area_type( string area ) {
if ( area == "AirportKeep" ) {
return AirportKeepArea;
} else if ( area == "AirportIgnore" ) {
return AirportIgnoreArea;
- } else if ( area == "Swamp or Marsh" ) {
+ } else if ( (area == "Swamp or Marsh")
+ || (area == "Marsh") ) {
return MarshArea;
- } else if ( area == "Bay Estuary or Ocean" ) {
+ } else if ( (area == "Bay Estuary or Ocean")
+ || (area == "Ocean") ) {
return OceanArea;
} else if ( area == "Lake" ) {
return LakeArea;
} else if ( area == "Lake Dry" ) {
return DryLakeArea;
- } else if ( area == "Lake Intermittent" ) {
+ } else if ( (area == "Lake Intermittent")
+ || (area == "IntermittentLake") ) {
return IntLakeArea;
} else if ( area == "Reservoir" ) {
return ReservoirArea;
} else {
cout << "unknown area = '" << area << "'" << endl;
// cout << "area = " << area << endl;
- for ( int i = 0; i < area.length(); i++ ) {
- cout << i << ") " << (int)area[i] << endl;
- }
+ // for ( int i = 0; i < area.length(); i++ ) {
+ // cout << i << ") " << (int)area[i] << endl;
+ // }
return UnknownArea;
}
}
-// return text form of area name
+// return text from of area name
string get_area_name( AreaType area ) {
if ( area == AirportKeepArea ) {
return "AirportKeep";
// $Log$
+// Revision 1.5 1999/03/22 23:49:29 curt
+// Moved AreaType get_shapefile_type(GDBFile *dbf, int rec) to where it
+// belongs in ShapeFile/
+//
+// Revision 1.4 1999/03/13 18:47:04 curt
+// Removed an unused variable.
+//
+// Revision 1.3 1999/03/02 01:03:58 curt
+// Added more reverse lookup support.
+//
+// Revision 1.2 1999/03/01 15:35:52 curt
+// Generalized the routines a bit to make them more useful.
+//
// Revision 1.1 1999/02/25 21:30:24 curt
// Initial revision.
//