mirror of
https://github.com/eried/portapack-mayhem.git
synced 2025-01-27 06:47:13 -05:00
Move entry update code into AISRecentEntry.
This commit is contained in:
parent
8efeb049ca
commit
8a30003ab6
@ -99,6 +99,44 @@ void AISLogger::on_packet(const ais::Packet& packet) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AISRecentEntry::update(const ais::Packet& packet) {
|
||||||
|
received_count++;
|
||||||
|
|
||||||
|
switch(packet.message_id()) {
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
case 3:
|
||||||
|
navigational_status = packet.read(38, 4);
|
||||||
|
last_position.timestamp = packet.received_at();
|
||||||
|
last_position.latitude = packet.latitude(89);
|
||||||
|
last_position.longitude = packet.longitude(61);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
// packet.datetime(38)
|
||||||
|
last_position.timestamp = packet.received_at();
|
||||||
|
last_position.latitude = packet.latitude(107);
|
||||||
|
last_position.longitude = packet.longitude(79);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 5:
|
||||||
|
call_sign = packet.text(70, 7);
|
||||||
|
name = packet.text(112, 20);
|
||||||
|
destination = packet.text(302, 20);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 21:
|
||||||
|
name = packet.text(43, 20);
|
||||||
|
last_position.timestamp = packet.received_at();
|
||||||
|
last_position.latitude = packet.latitude(192);
|
||||||
|
last_position.longitude = packet.longitude(164);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void AISRecentEntries::on_packet(const ais::Packet& packet) {
|
void AISRecentEntries::on_packet(const ais::Packet& packet) {
|
||||||
const auto source_id = packet.source_id();
|
const auto source_id = packet.source_id();
|
||||||
auto matching_recent = find_by_mmsi(source_id);
|
auto matching_recent = find_by_mmsi(source_id);
|
||||||
@ -111,42 +149,7 @@ void AISRecentEntries::on_packet(const ais::Packet& packet) {
|
|||||||
truncate_entries();
|
truncate_entries();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto& entry = entries.front();
|
entries.front().update(packet);
|
||||||
entry.received_count++;
|
|
||||||
|
|
||||||
switch(packet.message_id()) {
|
|
||||||
case 1:
|
|
||||||
case 2:
|
|
||||||
case 3:
|
|
||||||
entry.navigational_status = packet.read(38, 4);
|
|
||||||
entry.last_position.timestamp = packet.received_at();
|
|
||||||
entry.last_position.latitude = packet.latitude(89);
|
|
||||||
entry.last_position.longitude = packet.longitude(61);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 4:
|
|
||||||
// packet.datetime(38)
|
|
||||||
entry.last_position.timestamp = packet.received_at();
|
|
||||||
entry.last_position.latitude = packet.latitude(107);
|
|
||||||
entry.last_position.longitude = packet.longitude(79);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 5:
|
|
||||||
entry.call_sign = packet.text(70, 7);
|
|
||||||
entry.name = packet.text(112, 20);
|
|
||||||
entry.destination = packet.text(302, 20);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 21:
|
|
||||||
entry.name = packet.text(43, 20);
|
|
||||||
entry.last_position.timestamp = packet.received_at();
|
|
||||||
entry.last_position.latitude = packet.latitude(192);
|
|
||||||
entry.last_position.longitude = packet.longitude(164);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
AISRecentEntries::ContainerType::const_iterator AISRecentEntries::find_by_mmsi(const ais::MMSI key) const {
|
AISRecentEntries::ContainerType::const_iterator AISRecentEntries::find_by_mmsi(const ais::MMSI key) const {
|
||||||
|
@ -61,6 +61,8 @@ struct AISRecentEntry {
|
|||||||
navigational_status { -1 }
|
navigational_status { -1 }
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void update(const ais::Packet& packet);
|
||||||
};
|
};
|
||||||
|
|
||||||
class AISRecentEntries {
|
class AISRecentEntries {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user