//
// simple.cxx -- a really simplistic class to manage airport ID,
-// lat, lon of the center of one of it's runways, and
-// elevation in feet.
+// lat, lon of the center of one of it's runways, and
+// elevation in feet.
//
// Written by Curtis Olson, started April 1998.
//
//
// $Id$
-
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
-#include <sys/types.h> // for gdbm open flags
-#include <sys/stat.h> // for gdbm open flags
-
-#ifdef HAVE_GDBM
-# include <gdbm.h>
-#else
-# include <simgear/gdbm/gdbm.h>
-#endif
-
#include <simgear/compiler.h>
#include <simgear/debug/logstream.hxx>
-#include <simgear/misc/fgstream.hxx>
-
-#include <Main/options.hxx>
+#include <simgear/misc/sgstream.hxx>
#include STL_STRING
-#include STL_FUNCTIONAL
-#include STL_ALGORITHM
+#include STL_IOSTREAM
#include "simple.hxx"
+SG_USING_NAMESPACE(std);
+SG_USING_STD(istream);
-FGAirports::FGAirports( const string& file ) {
- dbf = gdbm_open( (char *)file.c_str(), 0, GDBM_READER, 0, NULL );
- if ( dbf == NULL ) {
- cout << "Error opening " << file << endl;
- exit(-1);
- } else {
- cout << "successfully opened " << file << endl;
- }
-}
-
-
-// search for the specified id
-bool
-FGAirports::search( const string& id, FGAirport* a ) const
-{
- FGAirport *tmp;
- datum content;
- datum key;
-
- key.dptr = (char *)id.c_str();
- key.dsize = id.length();
-
- content = gdbm_fetch( dbf, key );
-
- cout << "gdbm_fetch() finished" << endl;
-
- if ( content.dptr != NULL ) {
- tmp = (FGAirport *)content.dptr;
-
- // a->id = tmp->id;
- a->longitude = tmp->longitude;
- a->latitude = tmp->latitude;
- a->elevation = tmp->elevation;
- free( content.dptr );
-
- } else {
- return false;
- }
-
- return true;
-}
-
-
-FGAirport
-FGAirports::search( const string& id ) const
+inline istream&
+operator >> ( istream& in, FGAirport& a )
{
- FGAirport a, *tmp;
- datum content;
- datum key;
-
- key.dptr = (char *)id.c_str();
- key.dsize = id.length();
+ string junk;
+ in >> junk >> a.id >> a.latitude >> a.longitude >> a.elevation
+ >> a.code;
- content = gdbm_fetch( dbf, key );
-
- if ( content.dptr != NULL ) {
- tmp = (FGAirport *)content.dptr;
- a = *tmp;
- }
+ char name[256]; // should never be longer than this, right? :-)
+ in.getline( name, 256 );
+ a.name = name;
- return a;
+ return in;
}
-// Destructor
-FGAirports::~FGAirports( void ) {
- gdbm_close( dbf );
-}
-
-
-// Constructor
-FGAirportsUtil::FGAirportsUtil() {
-}
-
-
-// load the data
-int FGAirportsUtil::load( const string& file ) {
- FGAirport a;
+FGAirportList::FGAirportList( const string& file ) {
+ SG_LOG( SG_GENERAL, SG_DEBUG, "Reading simple airport list: " << file );
- airports.erase( airports.begin(), airports.end() );
-
- fg_gzifstream in( file );
+ // open the specified file for reading
+ sg_gzifstream in( file );
if ( !in.is_open() ) {
- FG_LOG( FG_GENERAL, FG_ALERT, "Cannot open file: " << file );
+ SG_LOG( SG_GENERAL, SG_ALERT, "Cannot open file: " << file );
exit(-1);
}
- /*
- // We can use the STL copy algorithm because the input
- // file doesn't contain and comments or blank lines.
- copy( istream_iterator<FGAirport,ptrdiff_t>(in.stream()),
- istream_iterator<FGAirport,ptrdiff_t>(),
- inserter( airports, airports.begin() ) );
- */
-
- // read in each line of the file
-
-#ifdef __MWERKS__
-
- in >> skipcomment;
- char c = 0;
- while ( in.get(c) && c != '\0' ) {
- in.putback(c);
- in >> a;
- airports.insert(a);
- in >> skipcomment;
- }
-
-#else
-
- in >> skipcomment;
- while ( ! in.eof() ) {
- in >> a;
- airports.insert(a);
- in >> skipcomment;
- }
-
-#endif
-
- return 1;
-}
-
-
-// save the data in gdbm format
-bool FGAirportsUtil::dump_gdbm( const string& file ) {
-
- GDBM_FILE dbf;
-
-#if !defined( MACOS )
- dbf = gdbm_open( (char *)file.c_str(), 0, GDBM_NEWDB | GDBM_FAST,
- S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH,
- NULL );
-#else
- dbf = gdbm_open( (char *)file.c_str(), 0, GDBM_NEWDB | GDBM_FAST,
- NULL, NULL );
-#endif
-
- if ( dbf == NULL ) {
- cout << "Error opening " << file << endl;
- exit(-1);
- } else {
- cout << "successfully opened " << file << endl;
- }
+ // skip header line
+ in >> skipeol;
- iterator current = airports.begin();
- const_iterator end = airports.end();
- while ( current != end ) {
- datum key;
- key.dptr = (char *)current->id.c_str();
- key.dsize = current->id.length();
-
- datum content;
- FGAirport tmp = *current;
- content.dptr = (char *)(& tmp);
- content.dsize = sizeof( *current );
-
- gdbm_store( dbf, key, content, GDBM_REPLACE );
-
- ++current;
+ FGAirport a;
+ while ( in ) {
+ in >> a;
+ airports[a.id] = a;
}
-
- gdbm_close( dbf );
-
- return true;
}
// search for the specified id
-bool
-FGAirportsUtil::search( const string& id, FGAirport* a ) const
-{
- const_iterator it = airports.find( FGAirport(id) );
- if ( it != airports.end() )
- {
- *a = *it;
- return true;
- }
- else
- {
- return false;
- }
-}
-
-
-FGAirport
-FGAirportsUtil::search( const string& id ) const
-{
- FGAirport a;
- this->search( id, &a );
- return a;
+FGAirport FGAirportList::search( const string& id) {
+ return airports[id];
}
// Destructor
-FGAirportsUtil::~FGAirportsUtil( void ) {
+FGAirportList::~FGAirportList( void ) {
}
-
-