Реализация сущности Client в примере ping

Сущность Client для вызывает методы Ping и Pong в различной последовательности.

Инициализация транспорта до сервера, использование прокси-объекта и интерфейсных методов, а также назначение файла Ping.idl.h рассматриваются более подробно в комментариях к файлу client.c в примере echo.

client.c

#include <stdio.h>

#include <stdlib.h>

#include <stdint.h>

/* Файлы, необходимые для инициализации транспорта. */

#include <coresrv/nk/transport-kos.h>

#include <coresrv/sl/sl_api.h>

/* Описание интерфейса сервера, по которому обращается клиентская сущность. */

#include <Ping.idl.h>

#include <assert.h>

#define EXAMPLE_VALUE_TO_SEND 777

static struct Ping_proxy proxy;

static uint32_t ping(uint32_t value)

{

/* Структуры запроса и ответа */

struct Ping_Ping_req req;

struct Ping_Ping_res res;

req.value = value;

/* Вызываем интерфейсный метод Ping_Ping.

* Серверу будет отправлен запрос для вызова метода Ping интерфейса

* pingComp.pingImpl с аргументом value. Вызывающий поток блокируется

* до момента получения ответа от сервера. */

if (Ping_Ping(&proxy.base, &req, NULL, &res, NULL) == rcOk)

{

fprintf(stderr, "Client: Ping(%d), result = %d\n", (int) value, (int) res.result);

value = res.result;

}

else

fprintf(stderr, "Client: Ping(%d), failed\n", (int) value);

return value;

}

static uint32_t pong(uint32_t value)

{

/* Структуры запроса и ответа */

struct Ping_Pong_req req;

struct Ping_Pong_res res;

req.value = value;

/* Вызываем интерфейсный метод Ping_Pong.

* Серверу будет отправлен запрос для вызова метода Pong интерфейса

* ping_comp.ping_impl с аргументом value. Вызывающий поток блокируется

* до момента получения ответа от сервера. */

if (Ping_Pong(&proxy.base, &req, NULL, &res, NULL) == rcOk)

{

fprintf(stderr, "Client: Pong(%d), result = %d\n", (int) value, (int) res.result);

value = res.result;

}

else

fprintf(stderr, "Client: Pong(%d), failed\n", (int) value);

return value;

}

/* Точка входа в клиентскую сущность. */

int main(int argc, const char *argv[])

{

NkKosTransport transport;

uint32_t value;

int i;

fprintf(stderr, "Hello I'm client\n");

/* Получаем клиентский IPC-дескриптор соединения с именем

* "server_connection". */

Handle handle = ServiceLocatorConnect("server_connection");

assert(handle != INVALID_HANDLE);

/* Инициализируем IPC-транспорт для взаимодействия с серверной сущностью. */

NkKosTransport_Init(&transport, handle, NK_NULL, 0);

/* Получаем идентификатор интерфейса pingComp.pingImpl. */

nk_iid_t riid = ServiceLocatorGetRiid(handle, "pingComp.pingImpl");

assert(riid != INVALID_RIID);

/* Инициализируем прокси-объект, указав транспорт (&transport)

* и идентификатор интерфейса сервера (riid). Каждый метод

* прокси-объекта будет реализован как отправка запроса серверу. */

Ping_proxy_init(&proxy, &transport.base, riid);

/* Тестовый цикл. */

value = EXAMPLE_VALUE_TO_SEND;

for (i = 0; i < 5; ++i)

{

value = ping(value);

value = pong(value);

}

value = ping(value);

value = ping(value);

value = pong(value);

value = pong(value);

return EXIT_SUCCESS;

}

В начало