54 {
55 std::string appName = "ccsds_encoder";
56
57 std::unordered_map<std::string, std::string> allowed;
58 allowed.insert({"h", "help"});
59 allowed.insert({"v", "verbose"});
60 allowed.insert({"i", "input"});
61 allowed.insert({"o", "output"});
62 allowed.insert({"c", "config"});
63
64 const std::set<std::string> booleanArgs{"verbose", "help"};
65
66 std::unordered_map<std::string, std::string> args;
67 args.insert({"verbose", "false"});
68 args.insert({"help", "false"});
69
70 const auto start = std::chrono::high_resolution_clock::now();
72 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
73 return res.error().code();
74 }
75
76
77
78
79 if (args["help"] == "true") {
81 return 0;
82 }
83 bool verbose{args["verbose"] == "true"};
84
85 if (args.find("input") == args.end()) {
86 std::cerr <<
"[ Error " <<
ARG_PARSE_ERROR <<
" ]: " <<
"Input file must be specified" << std::endl;
89 }
90
92 std::cerr <<
"[ Error " <<
ARG_PARSE_ERROR <<
" ]: " <<
"Input \"" << args[
"input"] <<
"\" does not exist" << std::endl;
94 }
95 const std::string input{args["input"]};
96 const std::string output{args["output"]};
97
98 if (output.empty()) {
99 std::cerr <<
"[ Error " <<
ARG_PARSE_ERROR <<
" ]: " <<
"Output file must be specified" << std::endl;
102 }
103
104 if (args.find("config") == args.end()) {
105 std::cerr <<
"[ Error " <<
ARG_PARSE_ERROR <<
" ]: " <<
"Config file must be specified" << std::endl;
108 }
109
111 std::cerr <<
"[ Error " <<
ARG_PARSE_ERROR <<
" ]: " <<
"Config \"" << args[
"config"] <<
"\" does not exist" << std::endl;
113 }
114 const std::string configFile{args["config"]};
115
116
117 customConsole(appName,
"reading CCSDS configuration file: " + configFile);
119 {
120 if (
auto res = cfg.
load(configFile); !res.has_value()) {
121 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
122 return res.error().code();
123 }
124 }
125
127
128 if (cfg.
isKey(
"data_field_size")) {
129 std::uint16_t dataFieldSize;
132 }
133
134 if (cfg.
isKey(
"sync_pattern_enable")) {
135 bool syncPatternEnable;
138 if (syncPatternEnable && cfg.
isKey(
"sync_pattern")) {
139 std::uint32_t syncPattern;
142 }
143 }
144
146
148 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
149 return res.error().code();
150 }
151
152 std::vector<std::uint8_t> inputBytes;
154
156 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
157 return res.error().code();
158 }else {
159 inputBytes = res.value();
161 std::cerr <<
"[ Error " <<
INVALID_INPUT_DATA <<
" ]: "<<
"Input data is too big for unsegmented packets, data "
162 << inputBytes.size() <<
" must be less than defined data packet length of " << manager.
getDataFieldSize() << std::endl ;
164 }
165 }
166
167 customConsole(appName,
"generating CCSDS packets using input data");
169 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
170 return res.error().code();
171 }
172 if (verbose)
customConsole(appName,
"printing data to screen:");
174
179 std::cerr << "[ Error " << res.error().code() << " ]: "<< res.error().message() << std::endl ;
180 return res.error().code();
181 }
182
183 const auto end = std::chrono::high_resolution_clock::now();
184 const auto duration = std::chrono::duration_cast<std::chrono::microseconds>(end - start);
185 customConsole(appName,
"execution time: " + std::to_string(duration.count()) +
" [us]");
187 return 0;
188}
#define ASSIGN_OR_PRINT(var, result)
Macro to assign a result value or print an error message.
bool fileExists(const std::string &fileName)
filesystem check fore file existence prepared for both windows and linux.
CCSDS::ResultBuffer readBinaryFile(const std::string &filename)
Read a specified binary file and return its contents as a buffer.
CCSDS::ResultBool writeBinaryFile(const std::vector< std::uint8_t > &data, const std::string &filename)
This function takes in a buffer of data and a file name.
void printPackets(CCSDS::Manager &manager)
Prints to console a series of CCSDS Packets contained in the manager.
Manages CCSDS packets and their templates.
void setSyncPatternEnable(bool enable)
enable sync pattern utilization both in serialization, deserialization, read and write.
std::uint16_t getDataFieldSize() const
retrieves the set data field size (this includes the secondary header if present)
void setSyncPattern(std::uint32_t syncPattern)
set sync pattern that should indicate the start of a CCSDS packet.
Packet getTemplate()
Retrieves the packet template.
ResultBool loadTemplateConfig(const Config &cfg)
Loads a template packet from a configuration object.
std::vector< std::uint8_t > getPacketsBuffer() const
Retrieves a buffer containing all the stored packets sequentially.
void setDataFieldSize(std::uint16_t size)
Sets the size of the data field.
ResultBool setApplicationData(const std::vector< std::uint8_t > &data)
Sets the application data for the packet.
Header & getPrimaryHeader()
returns the CCSDS packet's Primary Header.
bool has_value() const
Checks if the result contains a valid value.
Parses and stores config values from custom file format.
bool isKey(const std::string &key) const
CCSDS::ResultBool load(const std::string &filename)
Load config file.
CCSDS::Result< T > get(const std::string &key) const
Get value by key and type.
void printHelp()
This is the source file that holds the execution logic of ccsds_encoder binary file.
void customConsole(const std::string &appName, const std::string &message, const std::string &logLevel="INFO")
Prints log to console adding various information about.
CCSDS::ResultBool parseArguments(int argc, char *argv[], std::unordered_map< std::string, std::string > &allowedMap, std::unordered_map< std::string, std::string > &outArgs, const std::set< std::string > &booleanArgs)
Parses the input arguments with defined values returns an unordered map with given keys and input val...
@ ARG_PARSE_ERROR
Error Parsing argument.
@ UNSEGMENTED
11 Complete packet in a single frame.