2021-03-05 15:10:04 +00:00
|
|
|
#include "dds/dds.h"
|
|
|
|
#include "dds_fdm.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
/* An array of one message(aka sample in dds terms) will be used. */
|
|
|
|
#define MAX_SAMPLES 1
|
|
|
|
|
|
|
|
#ifndef _WIN32
|
|
|
|
# include <termios.h>
|
|
|
|
|
|
|
|
void set_mode(int want_key)
|
|
|
|
{
|
|
|
|
static struct termios old, new;
|
|
|
|
if (!want_key) {
|
|
|
|
tcsetattr(STDIN_FILENO, TCSANOW, &old);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
tcgetattr(STDIN_FILENO, &old);
|
|
|
|
new = old;
|
|
|
|
new.c_lflag &= ~(ICANON | ECHO);
|
|
|
|
tcsetattr(STDIN_FILENO, TCSANOW, &new);
|
|
|
|
}
|
|
|
|
|
|
|
|
int get_key()
|
|
|
|
{
|
|
|
|
int c = 0;
|
|
|
|
struct timeval tv;
|
|
|
|
fd_set fs;
|
|
|
|
tv.tv_usec = tv.tv_sec = 0;
|
|
|
|
|
|
|
|
FD_ZERO(&fs);
|
|
|
|
FD_SET(STDIN_FILENO, &fs);
|
|
|
|
select(STDIN_FILENO + 1, &fs, 0, 0, &tv);
|
|
|
|
|
|
|
|
if (FD_ISSET(STDIN_FILENO, &fs)) {
|
|
|
|
c = getchar();
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
# include <conio.h>
|
|
|
|
|
|
|
|
int get_key()
|
|
|
|
{
|
|
|
|
if (kbhit()) {
|
|
|
|
return getch();
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_mode(int want_key)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
dds_entity_t participant;
|
|
|
|
dds_entity_t topic;
|
|
|
|
dds_entity_t reader;
|
|
|
|
FG_DDS_FDM *fdm;
|
|
|
|
void *samples[MAX_SAMPLES];
|
|
|
|
dds_sample_info_t infos[MAX_SAMPLES];
|
|
|
|
dds_return_t rc;
|
|
|
|
dds_qos_t *qos;
|
|
|
|
|
|
|
|
/* Create a Participant. */
|
|
|
|
participant = dds_create_participant(DDS_DOMAIN_DEFAULT, NULL, NULL);
|
|
|
|
if(participant < 0)
|
|
|
|
DDS_FATAL("dds_create_participant: %s\n", dds_strretcode(-participant));
|
|
|
|
|
|
|
|
/* Create a Topic. */
|
|
|
|
topic = dds_create_topic(
|
|
|
|
participant, &FG_DDS_FDM_desc, "FG_DDS_FDM", NULL, NULL);
|
|
|
|
if(topic < 0)
|
|
|
|
DDS_FATAL("dds_create_topic: %s\n", dds_strretcode(-topic));
|
|
|
|
|
|
|
|
/* Create a reliable Reader. */
|
|
|
|
qos = dds_create_qos();
|
|
|
|
dds_qset_reliability(qos, DDS_RELIABILITY_RELIABLE, DDS_SECS(10));
|
|
|
|
reader = dds_create_reader(participant, topic, qos, NULL);
|
|
|
|
if(reader < 0)
|
|
|
|
DDS_FATAL("dds_create_reader: %s\n", dds_strretcode(-reader));
|
|
|
|
dds_delete_qos(qos);
|
|
|
|
|
|
|
|
printf("\n=== [fgfdm_log] Waiting for a sample ...\n");
|
|
|
|
fflush(stdout);
|
|
|
|
|
|
|
|
/* Initialize sample buffer, by pointing the void pointer within
|
|
|
|
* the buffer array to a valid sample memory location. */
|
|
|
|
samples[0] = FG_DDS_FDM__alloc ();
|
|
|
|
|
2021-03-23 13:30:52 +00:00
|
|
|
// wait set
|
|
|
|
dds_entity_t waitset = dds_create_waitset(participant);
|
|
|
|
dds_entity_t rdcond = dds_create_readcondition(reader,
|
|
|
|
DDS_NOT_READ_SAMPLE_STATE);
|
|
|
|
int status = dds_waitset_attach(waitset, rdcond, reader);
|
|
|
|
if (status < 0)
|
|
|
|
DDS_FATAL("ds_waitset_attach: %s\n", dds_strretcode(-status));
|
|
|
|
|
|
|
|
/* Wait for a new packet. */
|
2021-03-05 15:10:04 +00:00
|
|
|
set_mode(1);
|
2021-03-23 13:30:52 +00:00
|
|
|
|
|
|
|
size_t num = 1;
|
|
|
|
dds_attach_t results[num];
|
|
|
|
dds_duration_t timeout = DDS_MSECS(500);
|
|
|
|
while(dds_waitset_wait(waitset, results, num, timeout) >= 0)
|
2021-03-05 15:10:04 +00:00
|
|
|
{
|
|
|
|
/* Do the actual read.
|
|
|
|
* The return value contains the number of read samples. */
|
|
|
|
rc = dds_take(reader, samples, infos, 1, 1);
|
|
|
|
if(rc < 0)
|
|
|
|
DDS_FATAL("dds_read: %s\n", dds_strretcode(-rc));
|
|
|
|
|
|
|
|
/* Check if we read some data and it is valid. */
|
|
|
|
if((rc > 0) &&(infos[0].valid_data))
|
|
|
|
{
|
|
|
|
/* Print Message. */
|
|
|
|
fdm = (FG_DDS_FDM*) samples[0];
|
|
|
|
printf("=== [fgfdm_log] Received : ");
|
|
|
|
printf("FDM Message:\n");
|
|
|
|
printf(" version: %i\n", fdm->version);
|
|
|
|
printf(" longitude: %lf\n", fdm->longitude);
|
|
|
|
printf(" latitude: %lf\n", fdm->latitude);
|
|
|
|
printf(" altitude: %lf\n", fdm->altitude);
|
|
|
|
fflush(stdout);
|
|
|
|
// break;
|
|
|
|
}
|
2021-03-23 13:30:52 +00:00
|
|
|
|
|
|
|
if (get_key()) break;
|
2021-03-05 15:10:04 +00:00
|
|
|
}
|
|
|
|
set_mode(0);
|
|
|
|
|
|
|
|
/* Free the data location. */
|
|
|
|
FG_DDS_FDM_free (samples[0], DDS_FREE_ALL);
|
|
|
|
|
|
|
|
/* Deleting the participant will delete all its children recursively as well. */
|
|
|
|
rc = dds_delete(participant);
|
|
|
|
if(rc != DDS_RETCODE_OK)
|
|
|
|
DDS_FATAL("dds_delete: %s\n", dds_strretcode(-rc));
|
|
|
|
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|