From 68d23225a38a35f1325eb39fa4ed5a005d5de473 Mon Sep 17 00:00:00 2001
From: fujuntang <fujuntang@aiot.com>
Date: 星期三, 11 八月 2021 09:50:20 +0800
Subject: [PATCH] fix from 3.1 first commit

---
 src/net/net_mod_socket_wrapper.cpp |   47 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 37 insertions(+), 10 deletions(-)

diff --git a/src/net/net_mod_socket_wrapper.cpp b/src/net/net_mod_socket_wrapper.cpp
index 1dd2465..6f9a66e 100644
--- a/src/net/net_mod_socket_wrapper.cpp
+++ b/src/net/net_mod_socket_wrapper.cpp
@@ -20,6 +20,11 @@
 	delete sockt;
 }
  
+int net_mod_socket_stop(void *_socket) {
+	NetModSocket *sockt = (NetModSocket *)_socket;
+	return sockt->stop();
+}
+
 /**
  * 缁戝畾绔彛鍒皊ocket, 濡傛灉涓嶇粦瀹氬垯绯荤粺鑷姩鍒嗛厤涓�涓�
  * @return 0 鎴愬姛锛� 鍏朵粬鍊� 澶辫触鐨勯敊璇爜
@@ -35,8 +40,8 @@
 */
 int net_mod_socket_force_bind(void * _socket, int key) {
 	NetModSocket *sockt = (NetModSocket *)_socket;
-	// return sockt->force_bind(key);
-	return sockt->bind(key);
+	return sockt->force_bind(key);
+	// return sockt->bind(key);
 }
 
 /**
@@ -54,6 +59,7 @@
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	logger->debug("net_mod_socket_sendto: %d sendto  %d", net_mod_socket_get_key(_socket), key);
 	return sockt->sendto_timeout(buf, size, key, sec, nsec);
+	// return sockt->sendto(buf, size, key);
 }
 // 鍙戦�佷俊鎭珛鍒昏繑鍥炪��
 int net_mod_socket_sendto_nowait(void *_socket, const void *buf, const int size, const int key){
@@ -76,12 +82,14 @@
 	logger->debug(" %d net_mod_socket_recvfrom after. rv = %d", net_mod_socket_get_key(_socket), rv);
 	return rv;
 }
+
 // 鎺ュ彈淇℃伅瓒呮椂杩斿洖銆� @sec 绉� 锛� @nsec 绾崇
 int net_mod_socket_recvfrom_timeout(void *_socket, void **buf, int *size, int *key, int sec, int nsec){
 	NetModSocket *sockt = (NetModSocket *)_socket;
-	//return sockt->recvfrom(buf, size, key);
+	// return sockt->recvfrom(buf, size, key);
 	return sockt->recvfrom_timeout(buf, size, key, sec, nsec);
 }
+
 int net_mod_socket_recvfrom_nowait(void *_socket, void **buf, int *size, int *key){
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	return sockt->recvfrom_nowait(buf, size, key);
@@ -92,6 +100,7 @@
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	return sockt->sendandrecv(node_arr,  arrlen, send_buf,  send_size, recv_arr, recv_arr_size);
 }
+
 /**
  * 濡傛灉寤虹珛杩炴帴鐨勮妭鐐规病鏈夋帴鍙楀埌娑堟伅绛夊緟timeout鐨勬椂闂村悗杩斿洖
  * @timeout 绛夊緟鏃堕棿锛屽崟浣嶆槸鍗冨垎涔嬩竴绉�
@@ -99,6 +108,7 @@
 int net_mod_socket_sendandrecv_timeout(void *_socket, net_node_t *node_arr, int arrlen, void *send_buf, int send_size, 
   net_mod_recv_msg_t ** recv_arr, int *recv_arr_size,  int timeout){
 	NetModSocket *sockt = (NetModSocket *)_socket;
+	// return sockt->sendandrecv(node_arr,  arrlen, send_buf,  send_size, recv_arr, recv_arr_size);
 	return sockt->sendandrecv_timeout(node_arr,  arrlen, send_buf,  send_size, recv_arr, recv_arr_size, timeout);
 }
 
@@ -108,7 +118,25 @@
 	return sockt->sendandrecv_nowait(node_arr,  arrlen, send_buf,  send_size, recv_arr, recv_arr_size);
 }
 
- 
+
+int net_mod_socket_recvandsend(void *_socket, recvandsend_callback_wrapper_fn callback, void * user_data) {
+  NetModSocket *sockt = (NetModSocket *)_socket;
+  return sockt->recvandsend(  callback, NULL, 0, user_data);
+
+}
+
+int net_mod_socket_recvandsend_timeout(void *_socket, recvandsend_callback_wrapper_fn callback,
+                                       int sec, int nsec, void * user_data) {
+  NetModSocket *sockt = (NetModSocket *)_socket;
+  struct timespec timeout = {sec, nsec};
+  return sockt->recvandsend(  callback, &timeout, BUS_TIMEOUT_FLAG, user_data);
+}
+
+int net_mod_socket_recvandsend_nowait(void *_socket,  recvandsend_callback_wrapper_fn callback, void * user_data) {
+  NetModSocket *sockt = (NetModSocket *)_socket;
+  return sockt->recvandsend(  callback, NULL, BUS_NOWAIT_FLAG, user_data);
+}
+
 
  /**
  * 鍚憂ode_arr 涓殑鎵�鏈夌綉缁滆妭鐐瑰彂甯冩秷鎭�
@@ -117,15 +145,15 @@
  * @content 鍐呭锛孈content_size 鍐呭闀垮害
  * @return 鎴愬姛鍙戝竷鐨勮妭鐐圭殑涓暟
  */
-int net_mod_socket_pub(void *_socket, net_node_t *node_arr, int node_arr_len, char *topic, int topic_size, void *content, int content_size) {
+int net_mod_socket_pub(void *_socket, net_node_t *node_arr, int node_arr_len, const char *topic, int topic_size, const void *content, int content_size) {
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	return sockt->pub(node_arr, node_arr_len, topic, topic_size, content, content_size);
 }
-int net_mod_socket_pub_timeout(void *_socket, net_node_t *node_arr, int node_arr_len, char *topic, int topic_size, void *content, int content_size, int msec){
+int net_mod_socket_pub_timeout(void *_socket, net_node_t *node_arr, int node_arr_len, const char *topic, int topic_size, const void *content, int content_size, int msec){
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	return sockt->pub_timeout(node_arr, node_arr_len, topic, topic_size, content, content_size, msec);
 }
-int net_mod_socket_pub_nowait(void *_socket, net_node_t *node_arr, int node_arr_len, char *topic, int topic_size, void *content, int content_size){
+int net_mod_socket_pub_nowait(void *_socket, net_node_t *node_arr, int node_arr_len, const char *topic, int topic_size, const void *content, int content_size){
 	NetModSocket *sockt = (NetModSocket *)_socket;
 	return sockt->pub_nowait(node_arr, node_arr_len, topic, topic_size, content, content_size);
 }
@@ -207,10 +235,9 @@
 
 
 int shm_mod_socket_remove_keys(int keys[], int length){
-	return ShmModSocket::remove_keys(keys, length);
+	return 0;
 }
 
 int shm_mod_socket_remove_key(int key){
-	int keys[] = {key};
-	return ShmModSocket::remove_keys(keys, 1);
+	return 0;
 }

--
Gitblit v1.8.0