1
1
openmpi/src/lam/ctnetwork/ctchannel.c
David Daniel d4087af051 Making constructors and destructors static
This commit was SVN r726.
2004-02-11 14:37:25 +00:00

189 строки
4.4 KiB
C

/*
* $HEADER$
*/
#include <string.h>
#include "lam/ctnetwork/ctchannel.h"
#define CHANNEL_CLS(chnl) \
((lam_ctchannel_class_t *)(((lam_object_t *) chnl)->obj_class))
static void lam_cth_construct(lam_ctchannel_t *channel)
{
OBJ_CONSTRUCT_SUPER(channel, lam_object_t);
channel->cth_status = CT_CHNL_CLOSED;
channel->cth_id = 0;
channel->cth_timeout_secs = 0;
}
static void lam_cth_construct(lam_ctchannel_t *channel)
{
OBJ_DESTRUCT_SUPER(channel, lam_object_t);
}
lam_ctchannel_class_t lam_ct_channel_t_class_info = {
{
"lam_ct_channel_t",
CLASS_INFO(lam_object_t),
(lam_construct_t) lam_cth_construct,
(lam_destruct_t) lam_object_destruct
},
NULL, NULL, NULL, NULL, NULL, NULL
};
/*
*
* PURE VIRTUAL functions that must be
* implemented by concrete subclasses.
*
*/
/* return: error code args: (channel, data, data length, bytes sent) */
uint32_t lam_cth_send(lam_ctchannel_t *channel, const uint8_t *data,
uint32_t data_len, uint32_t *bytes_sent)
{
return CHANNEL_CLS(channel)->cth_send(channel, data, data_len,
bytes_sent);
}
/* return: error code args: (channel, recv buffer, buffer length, bytes received) */
uint32_t lam_cth_recv(lam_ctchannel_t *channel, const uint8_t *buffer,
uint32_t buff_len, uint32_t *bytes_recvd)
{
return CHANNEL_CLS(channel)->cth_recv(channel, buffer,
buff_len, bytes_recvd);
}
/* return: error code args: (channel, msg ptr) */
uint32_t lam_cth_get_msg(lam_ctchannel_t *channel, lam_ctmsg_t **msg)
{
return CHANNEL_CLS(channel)->cth_get_msg(channel, msg);
}
/* return: error code args: (channel, recv buffer ptr, bytes received) */
uint32_t lam_cth_get_packed_msg(lam_ctchannel_t *channel,
const uint8_t **buffer,
uint32_t *bytes_recvd)
{
return CHANNEL_CLS(channel)->cth_get_packed_msg(channel, buffer,
bytes_recvd);
}
/* return: error code args: (channel, msg) */
uint32_t lam_cth_send_msg(lam_ctchannel_t *channel, lam_ctmsg_t *msg)
{
return CHANNEL_CLS(channel)->cth_send_msg(channel, msg);
}
/* return: error code args: (channel, msg ptr, msg len) */
uint32_t lam_cth_send_packed_msg(lam_ctchannel_t *channel,
const uint8_t *packed_msg,
uint32_t msg_len)
{
return CHANNEL_CLS(channel)->cth_send_packed_msg(channel, packed_msg,
msg_len);
}
/*
*
* TCP channel class
*
*/
static void lam_tcpch_construct(lam_tcp_chnl_t *channel)
{
OBJ_CONSTRUCT_SUPER(channel, lam_object_t);
channel->tcp_sockfd = 0;
memset(&(channel->tcp_addr), 0, sizeof(channel->tcp_addr));
channel->tcp_blocking = 0;
}
static void lam_tcpch_destruct(lam_tcp_chnl_t *channel)
{
OBJ_DESTRUCT_SUPER(channel, lam_ct_channel_t);
}
lam_ctchannel_class_t lam_tcp_chnl_t_class_info = {
{
"lam_tcp_chnl_t",
CLASS_INFO(lam_ctchannel_t),
(lam_construct_t) lam_tcpch_construct,
(lam_destruct_t) lam_tcpch_destruct
},
lam_tcpch_send,
lam_tcpch_recv,
lam_tcpch_get_msg,
lam_tcpch_get_packed_msg,
lam_tcpch_send_msg,
lam_tcpch_send_packed_msg
};
uint32_t lam_tcpch_send(lam_tcp_chnl_t *channel, const uint8_t *data,
uint32_t data_len, uint32_t *bytes_sent)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}
uint32_t lam_tcpch_recv(lam_tcp_chnl_t *channel, const uint8_t *buffer,
uint32_t buff_len, uint32_t *bytes_recvd)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}
uint32_t lam_tcpch_get_msg(lam_tcp_chnl_t *channel, lam_ctmsg_t **msg)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}
uint32_t lam_tcpch_get_packed_msg(lam_tcp_chnl_t *channel,
const uint8_t **buffer,
uint32_t *bytes_recvd)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}
uint32_t lam_tcpch_send_msg(lam_tcp_chnl_t *channel, lam_ctmsg_t *msg)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}
uint32_t lam_tcpch_send_packed_msg(lam_tcp_chnl_t *channel,
const uint8_t *packed_msg,
uint32_t msg_len)
{
uint32_t ret = CT_CHNL_ERR_OK;
return ret;
}