2019-01-18 14:10:19 +01:00
|
|
|
#include "dds/dds.h"
|
2018-04-10 17:03:59 +02:00
|
|
|
#include "HelloWorldData.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
|
|
|
|
|
|
|
|
int main (int argc, char ** argv)
|
|
|
|
{
|
2019-01-18 14:10:19 +01:00
|
|
|
dds_entity_t participant;
|
|
|
|
dds_entity_t topic;
|
|
|
|
dds_entity_t reader;
|
|
|
|
HelloWorldData_Msg *msg;
|
|
|
|
void *samples[MAX_SAMPLES];
|
|
|
|
dds_sample_info_t infos[MAX_SAMPLES];
|
|
|
|
dds_return_t rc;
|
|
|
|
dds_qos_t *qos;
|
|
|
|
(void)argc;
|
|
|
|
(void)argv;
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* 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));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* Create a Topic. */
|
|
|
|
topic = dds_create_topic (
|
|
|
|
participant, &HelloWorldData_Msg_desc, "HelloWorldData_Msg", NULL, NULL);
|
|
|
|
if (topic < 0)
|
|
|
|
DDS_FATAL("dds_create_topic: %s\n", dds_strretcode(-topic));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* 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);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
printf ("\n=== [Subscriber] Waiting for a sample ...\n");
|
2019-03-23 12:59:31 +01:00
|
|
|
fflush (stdout);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* Initialize sample buffer, by pointing the void pointer within
|
|
|
|
* the buffer array to a valid sample memory location. */
|
|
|
|
samples[0] = HelloWorldData_Msg__alloc ();
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* Poll until data has been read. */
|
|
|
|
while (true)
|
|
|
|
{
|
|
|
|
/* Do the actual read.
|
|
|
|
* The return value contains the number of read samples. */
|
|
|
|
rc = dds_read (reader, samples, infos, MAX_SAMPLES, MAX_SAMPLES);
|
|
|
|
if (rc < 0)
|
|
|
|
DDS_FATAL("dds_read: %s\n", dds_strretcode(-rc));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* Check if we read some data and it is valid. */
|
|
|
|
if ((rc > 0) && (infos[0].valid_data))
|
|
|
|
{
|
|
|
|
/* Print Message. */
|
|
|
|
msg = (HelloWorldData_Msg*) samples[0];
|
|
|
|
printf ("=== [Subscriber] Received : ");
|
2019-04-01 12:03:09 +02:00
|
|
|
printf ("Message (%"PRId32", %s)\n", msg->userID, msg->message);
|
2019-03-23 12:59:31 +01:00
|
|
|
fflush (stdout);
|
2019-01-18 14:10:19 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Polling sleep. */
|
|
|
|
dds_sleepfor (DDS_MSECS (20));
|
2018-04-10 17:03:59 +02:00
|
|
|
}
|
2019-01-18 14:10:19 +01:00
|
|
|
}
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* Free the data location. */
|
|
|
|
HelloWorldData_Msg_free (samples[0], DDS_FREE_ALL);
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
/* 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));
|
2018-04-10 17:03:59 +02:00
|
|
|
|
2019-01-18 14:10:19 +01:00
|
|
|
return EXIT_SUCCESS;
|
2018-04-10 17:03:59 +02:00
|
|
|
}
|