blob: 19a1cb9f559eca13ca04e2e952a4c61ee40a5326 [file] [log] [blame]
Ravago Jones09067de2023-03-29 18:44:43 -07001#ifndef FRC971_CAN_LOGGER_ASC_LOGGER_H_
2#define FRC971_CAN_LOGGER_ASC_LOGGER_H_
3
4#include <iomanip>
5#include <iostream>
6
Ravago Jones09067de2023-03-29 18:44:43 -07007#include "gflags/gflags.h"
8#include "glog/logging.h"
9
Philipp Schrader790cb542023-07-05 21:06:52 -070010#include "aos/events/event_loop.h"
11#include "frc971/can_logger/can_logging_generated.h"
12
Ravago Jones09067de2023-03-29 18:44:43 -070013namespace frc971 {
14namespace can_logger {
15
16class AscLogger {
17 public:
18 AscLogger(aos::EventLoop *event_loop, const std::string &filename);
19
20 private:
21 void HandleFrame(const CanFrame &frame);
22
23 // This implementation attempts to duplicate the output of can-utils/log2asc
24 void WriteFrame(std::ostream &file, const CanFrame &frame);
25
26 static void WriteHeader(std::ostream &file,
27 aos::realtime_clock::time_point start_time);
28
29 std::optional<aos::monotonic_clock::time_point> first_frame_monotonic_;
30
31 std::ofstream output_;
32
33 aos::EventLoop *event_loop_;
34};
35
36} // namespace can_logger
37} // namespace frc971
38
39#endif // FRC971_CAN_LOGGER_ASC_LOGGER_H_