receive handler

This commit is contained in:
/jdi/ 2015-09-26 01:24:03 +02:00
parent 1ec3b6c4f0
commit 8607e4b370
5 changed files with 51 additions and 37 deletions

View file

@ -39,6 +39,22 @@ int Program::list() {
asio::io_service io_service;
Socket s(io_service);
s.init(dst_port, src_port);
s.callback = [](Packet a) {
utils::printSets(a.getPayload());
/*
sleep(1);
bytes b = {255, 255, 0, 0};
Host h = Host();
p = Packet(Packet::DISCOVERY);
p.setBody(b);
p.setHostMac(h.getMac());
bytes a = p.getBytes();
p.encode(a);
send(a);
*/
return 1;
};
s.send(a);
io_service.run();
} catch (std::exception& e) {

View file

@ -8,37 +8,39 @@
#ifndef TYPES_H_
#define TYPES_H_
#include <functional>
#include <vector>
#include <map>
template <typename T>
std::vector<T> operator+(const std::vector<T> &A, const std::vector<T> &B)
{
std::vector<T> AB;
AB.reserve( A.size() + B.size() ); // preallocate memory
AB.insert( AB.end(), A.begin(), A.end() ); // add A;
AB.insert( AB.end(), B.begin(), B.end() ); // add B;
return AB;
template<typename T>
std::vector<T> operator+(const std::vector<T> &A, const std::vector<T> &B) {
std::vector<T> AB;
AB.reserve(A.size() + B.size()); // preallocate memory
AB.insert(AB.end(), A.begin(), A.end()); // add A;
AB.insert(AB.end(), B.begin(), B.end()); // add B;
return AB;
}
template <typename T>
std::vector<T> &operator+=(std::vector<T> &A, const std::vector<T> &B)
{
A.reserve( A.size() + B.size() ); // preallocate memory without erase original data
A.insert( A.end(), B.begin(), B.end() ); // add B;
return A; // here A could be named AB
template<typename T>
std::vector<T> &operator+=(std::vector<T> &A, const std::vector<T> &B) {
A.reserve(A.size() + B.size());
A.insert(A.end(), B.begin(), B.end());
return A;
}
typedef std::vector<unsigned char> bytes;
typedef unsigned char byte;
struct dataset{
short type;
short len;
bytes value;
struct dataset {
short type;
short len;
bytes value;
};
//typedef std::vector<dataset> datasets;
typedef std::map<short,dataset> datasets;
typedef std::map<short, dataset> datasets;
//std::function<int()>;
//typedef int receiveCallback;
#endif /* TYPES_H_ */

View file

@ -17,7 +17,7 @@
#include "Program.h"
#define USAGE "Usage: smrtlink [-p n|--port n] [-h|--help] [-v|--version] name\n"
#define USAGE "Usage: smrtlink [-p n|--port n] [-h|--help] [-v|--version] <command>\n"
#define flag_version 1
#define flag_help 2
@ -77,19 +77,20 @@ int main(int argc, char *argv[]) {
if (optind < argc) {
if (strcmp(argv[optind], "list") == 0) {
optind++;
if (p.list())
exit(EXIT_SUCCESS);
else
exit(EXIT_FAILURE);
} else {
printf("Unknown Command: %s\n", argv[optind]);
printf("Unknown command: %s\n", argv[optind]);
optind++;
while (optind < argc) {
printf("->%s\n", argv[optind]);
optind++;
}
exit(EXIT_FAILURE);
}
optind++;
}
}

View file

@ -67,20 +67,9 @@ void Socket::listen() {
p.encode(data_);
p.parse(data_);
datasets l = p.getPayload();
utils::printSets(l);
/*
sleep(1);
bytes b = {255, 255, 0, 0};
Host h = Host();
p = Packet(Packet::DISCOVERY);
p.setBody(b);
p.setHostMac(h.getMac());
bytes a = p.getBytes();
p.encode(a);
send(a);
*/
listen();
if(!callback(p)) {
listen();
}
}
});

View file

@ -9,6 +9,7 @@
#define SOCKET_H_
#include <asio.hpp>
#include "Packet.h"
#include "../Types.h"
#define MAX_LENGTH 1024
@ -16,10 +17,15 @@
class Socket {
public:
Socket(asio::io_service&);
virtual ~Socket(){};
virtual ~Socket() {
}
void init(short, short);
void send(bytes);
void listen();
int (*callback)(Packet)=[](Packet a) {
return 0;
};
private:
asio::ip::udp::socket send_socket_;
asio::ip::udp::socket receive_socket_;