src/libais/ais_decode_normed.cpp
// This file is deprecated. I plan to make a new C++ decoder based on vdm.cc
// and to make C++ based TAG Block and USCG metadata handlers.
//
// Do not expect this file to build or really work.
#include "ais.h"
#include <fstream>
#include <iostream>
#include <cstring>
#include <sstream>
#include <string>
using std::stringstream;
// http://stackoverflow.com/questions/236129/c-how-to-split-a-string
vector<std::string> &split(
const std::string &s, char delim, vector<std::string> &elems) {
stringstream ss(s);
std::string item;
while (std::getline(ss, item, delim)) {
elems.push_back(item);
}
return elems;
}
vector<std::string> split(const std::string &s, char delim) {
vector<std::string> elems;
return split(s, delim, elems);
}
int main(int argc, char* argv[]) {
assert(2 <= argc);
std::ifstream infile(argv[1]);
if (!infile.is_open()) {
std::cerr << "Unable to open file: " << argv[1] << std::endl;
exit(1);
}
int i = 0;
std::string line;
while (!infile.eof()) {
i++;
getline(infile, line); // G++ problem with this and a string
if (line.size() < 20) {continue;}
if ('!' != line[0] || 'A' != line[1] ) {continue;}
std::string line_str(line);
vector<std::string> fields = split(line_str, ',');
{
if (fields.size() < 7) continue;
if (fields[5].size() < 5) continue;
if (fields[5][0] != '5') continue;
Ais5 m5(fields[5].c_str(), 2);
if (m5.had_error()) continue;
std::cout << m5.mmsi << "," << m5.name << "," << m5.callsign << ","
<< m5.type_and_cargo << std::endl;
}
}
return 0;
}