File indexing completed on 2024-09-08 03:35:20

0001 // SPDX-License-Identifier: LGPL-2.1-or-later
0002 //
0003 // SPDX-FileCopyrightText: 2006-2007 Torsten Rahn <tackat@kde.org>
0004 // SPDX-FileCopyrightText: 2007 Inge Wallin <ingwa@kde.org>
0005 // SPDX-FileCopyrightText: 2010 Harshit Jain <hjain.itbhu@gmail.com>
0006 //
0007 
0008 
0009 #include <QCoreApplication>
0010 #include <QDebug>
0011 #include <QFile>
0012 #include <QStringList>
0013 
0014 
0015 QString escapeXml( const QString &str )
0016 {
0017     QString xml = str;
0018     xml.replace(QLatin1Char('&'), QStringLiteral("&amp;"));
0019     xml.replace(QLatin1Char('<'), QStringLiteral("&lt;"));
0020     xml.replace(QLatin1Char('>'), QStringLiteral("&gt;"));
0021     xml.replace(QLatin1Char('\''), QStringLiteral("&apos;"));
0022     xml.replace(QLatin1Char('"'), QStringLiteral("&quot;"));
0023 
0024     return xml;
0025 }
0026 
0027 
0028 int main(int argc, char *argv[])
0029 {
0030     QCoreApplication  app( argc, argv );
0031 
0032     for ( int i = 1; i < argc; ++i ) {
0033         if ( strcmp( argv[ i ], "-o" ) != 0 )
0034             continue;
0035 
0036         const QString targetfilename   = QString( argv[i+1] );
0037         const QString sourcefilename   = QString( argv[i+2] );
0038         const QString supportfilename  = QString( argv[i+3] );
0039         const QString timezonefilename = QString( argv[i+4] );
0040 
0041         qDebug() << "Source: " << sourcefilename;
0042         qDebug() << "Support: " << supportfilename;
0043         qDebug() << "Target: " << targetfilename;
0044         qDebug() << "Timezone: " << timezonefilename;
0045 
0046         QFile  sourcefile( sourcefilename );
0047         sourcefile.open( QIODevice::ReadOnly );
0048 
0049         // Read the data serialized from the file.
0050         QTextStream  sourcestream( &sourcefile );
0051         sourcestream.setCodec("UTF-8");
0052 
0053         QFile  targetfile( targetfilename );
0054         targetfile.open( QIODevice::WriteOnly );
0055 
0056         QTextStream  targetstream( &targetfile );
0057         targetstream.setCodec("UTF-8");
0058 
0059         QFile  supportfile( supportfilename );
0060         supportfile.open( QIODevice::ReadOnly );
0061 
0062         QTextStream  supportstream( &supportfile );
0063         supportstream.setCodec("UTF-8");
0064 
0065         QFile  timezonefile( timezonefilename );
0066         timezonefile.open( QIODevice::ReadOnly );
0067 
0068         QTextStream  timezonestream( &timezonefile );
0069         timezonestream.setCodec("UTF-8");
0070 
0071         // gzFile gzDoc = gzopen( targetfilename.toLatin1(), "w");
0072         // QTextStream targetstream( new QString() );
0073 
0074         targetstream << "<?xml version=\"1.0\" encoding=\"UTF-8\"?> \n"
0075                      << "<kml xmlns=\"http://www.opengis.net/kml/2.2\"> \n"
0076                      << "<Document> \n";
0077         QString  state;
0078         QString  gmt;
0079         QString  dst;
0080 
0081         while ( !sourcestream.atEnd() ) {
0082 
0083             const QString rawline = sourcestream.readLine();
0084             const QStringList splitline = rawline.split(QLatin1Char('\t'));
0085 
0086             const QString name       = splitline[1];
0087             const QString latstring  = splitline[4];
0088             const QString lngstring  = splitline[5];
0089             const QString role       = splitline[7];
0090             const QString country    = splitline[8];
0091             const QString statecode  = splitline[10];
0092             const QString popstring  = splitline[14];
0093             const QString elestring  = splitline[16];
0094             const QString timezone   = splitline[17];
0095     
0096             supportstream.seek(0);
0097             while ( !supportstream.atEnd() ) {
0098                 const QString supportrawline = supportstream.readLine();
0099                 const QStringList supportsplitline = supportrawline.split(QLatin1Char('\t'));
0100                 if (supportsplitline[0] == (country + QLatin1Char('.') +statecode)) {
0101                     state = supportsplitline[1];
0102                     break;
0103                 }
0104             }   
0105 
0106             timezonestream.seek(0);
0107             timezonestream.readLine();
0108             while ( !timezonestream.atEnd() ) {
0109                     const QString timezonerawline = timezonestream.readLine();
0110                     const QStringList timezonesplitline = timezonerawline.split(QLatin1Char('\t'));
0111 
0112                     if( timezonesplitline[1] == timezone )
0113                     {
0114                         gmt = timezonesplitline[2];
0115                         dst = timezonesplitline[3];
0116                         break;
0117                     }
0118             }
0119 
0120             const int gmtoffset = ( int ) ( gmt.toFloat() * 100 );
0121             const int dstoffset = ( int ) ( dst.toFloat() * 100 ) - gmtoffset;
0122     
0123             if (role != QLatin1String("PPLX")) {
0124                 targetstream << "    <Placemark> \n";
0125                 targetstream << "        <name>" << escapeXml( name ) << "</name> \n";
0126                 targetstream << "        <state>" << escapeXml( state ) << "</state> \n";
0127                 targetstream << "        <CountryNameCode>" << escapeXml( country.toUpper() ) << "</CountryNameCode>\n";
0128                 targetstream << "        <role>" << escapeXml( role ) << "</role> \n";
0129                 targetstream << "        <pop>"
0130                              << escapeXml( popstring ) << "</pop> \n";
0131                 targetstream << "        <Point>\n"
0132                              << "            <coordinates>"
0133                              << escapeXml( lngstring )
0134                              << ","
0135                              << escapeXml( latstring )
0136                 << ","
0137                              << escapeXml( elestring )
0138                              << "</coordinates> \n"
0139                              << "        </Point> \n";
0140                 targetstream << "        <ExtendedData>\n"
0141                                  << "            <Data name=\"gmt\">\n"
0142                                  << "                <value>" << escapeXml( QString::number( gmtoffset ) ) << "</value>\n"
0143                                  << "            </Data>\n";
0144                     if( dstoffset )
0145                     {
0146                         targetstream << "            <Data name=\"dst\">\n"
0147                                  << "                <value>" << escapeXml( QString::number( dstoffset) ) << "</value>\n"
0148                                  << "            </Data>\n";
0149                     }
0150                     targetstream << "        </ExtendedData>\n";  
0151                 targetstream << "    </Placemark> \n";
0152             }
0153         }
0154 
0155         targetstream << "</Document> \n"
0156                      << "</kml> \n";
0157         qDebug("Putting");
0158 
0159         // gzputs( gzDoc, targetstream.readAll().toUtf8() );
0160         // gzclose( gzDoc );
0161 
0162         sourcefile.close();
0163         targetfile.close();
0164         supportfile.close();
0165         timezonefile.close();
0166         qDebug("Finished!");
0167         return 0;
0168     }
0169 
0170     qDebug(" asc2kml -o targetfile sourcefile supporfile timezonefile");
0171     app.exit();
0172 }