From ad4f3dcedab29a690c5eedbb08ba1b393917db0b Mon Sep 17 00:00:00 2001
From: lichao <lichao@aiotlink.com>
Date: 星期三, 21 四月 2021 17:39:34 +0800
Subject: [PATCH] update go api.

---
 /dev/null                    |    1 
 api/bhsgo/bhome_node_test.go |   15 +++++++
 go.sum                       |   31 +++++++++++++++
 api/bhsgo/bhome_node.go      |   42 ++++++---------------
 go.mod                       |    2 +
 api/bhsgo/bh_api_go.h        |   10 ++--
 6 files changed, 65 insertions(+), 36 deletions(-)

diff --git a/api/bhsgo/bh_api.h b/api/bhsgo/bh_api.h
deleted file mode 100644
index 627e3b4..0000000
--- a/api/bhsgo/bh_api.h
+++ /dev/null
@@ -1 +0,0 @@
-../../src/bh_api.h
\ No newline at end of file
diff --git a/api/bhsgo/bh_api_go.h b/api/bhsgo/bh_api_go.h
index cc22172..ba0b6f5 100644
--- a/api/bhsgo/bh_api_go.h
+++ b/api/bhsgo/bh_api_go.h
@@ -18,21 +18,21 @@
 #ifndef BH_API_GO_NVOG9GI5
 #define BH_API_GO_NVOG9GI5
 
-#include "bh_api.h"
+#include "../../src/bh_api.h"
 
 typedef const void *PCVoid;
-extern void CGoSubDataCallback(PCVoid proc_id,
+extern void cgoSubDataCallback(PCVoid proc_id,
                                int proc_id_len,
                                PCVoid data,
                                int data_len);
 
-extern void CGoServerCallback(PCVoid proc_id,
+extern void cgoServerCallback(PCVoid proc_id,
                               int proc_id_len,
                               PCVoid data,
                               int data_len,
                               void *src);
 
-extern void CGoClientCallback(PCVoid proc_id,
+extern void cgoClientCallback(PCVoid proc_id,
                               int proc_id_len,
                               PCVoid msg_id,
                               int msg_id_len,
@@ -41,7 +41,7 @@
 
 static void CGoStartWorker()
 {
-	BHStartWorker(&CGoServerCallback, &CGoSubDataCallback, &CGoClientCallback);
+	BHStartWorker(&cgoServerCallback, &cgoSubDataCallback, &cgoClientCallback);
 }
 
 #endif // end of include guard: BH_API_GO_NVOG9GI5
diff --git a/api/bhsgo/bhome_node.go b/api/bhsgo/bhome_node.go
index dcc8248..c5d4019 100644
--- a/api/bhsgo/bhome_node.go
+++ b/api/bhsgo/bhome_node.go
@@ -9,11 +9,10 @@
 
 import (
 	bh "bhshmq/proto/source/bhome_msg"
-	"fmt"
 	"unsafe"
 )
 
-func BHApiIn1Out1(bhfunc C.FBHApiIn1Out1, data []byte, reply *bh.MsgCommonReply, timeout_ms int) bool {
+func bhApiIn1Out1(bhfunc C.FBHApiIn1Out1, data []byte, reply *bh.MsgCommonReply, timeout_ms int) bool {
 	creply := unsafe.Pointer(nil)
 	creply_len := C.int(0)
 	defer C.BHFree(creply, creply_len)
@@ -27,22 +26,22 @@
 
 func Register(proc *bh.ProcInfo, reply *bh.MsgCommonReply, timeout_ms int) bool {
 	data, _ := proc.Marshal()
-	return BHApiIn1Out1(C.FBHApiIn1Out1(C.BHRegister), data, reply, timeout_ms)
+	return bhApiIn1Out1(C.FBHApiIn1Out1(C.BHRegister), data, reply, timeout_ms)
 }
 
 func RegisterTopics(topics *bh.MsgTopicList, reply *bh.MsgCommonReply, timeout_ms int) bool {
 	data, _ := topics.Marshal()
-	return BHApiIn1Out1(C.FBHApiIn1Out1(C.BHRegisterTopics), data, reply, timeout_ms)
+	return bhApiIn1Out1(C.FBHApiIn1Out1(C.BHRegisterTopics), data, reply, timeout_ms)
 }
 
 func Subscribe(topics *bh.MsgTopicList, reply *bh.MsgCommonReply, timeout_ms int) bool {
 	data, _ := topics.Marshal()
-	return BHApiIn1Out1(C.FBHApiIn1Out1(C.BHSubscribeTopics), data, reply, timeout_ms)
+	return bhApiIn1Out1(C.FBHApiIn1Out1(C.BHSubscribeTopics), data, reply, timeout_ms)
 }
 
-func Heartbeat(topics *bh.MsgTopicList, reply *bh.MsgCommonReply, timeout_ms int) bool {
+func Heartbeat(topics *bh.ProcInfo, reply *bh.MsgCommonReply, timeout_ms int) bool {
 	data, _ := topics.Marshal()
-	return BHApiIn1Out1(C.FBHApiIn1Out1(C.BHHeartbeat), data, reply, timeout_ms)
+	return bhApiIn1Out1(C.FBHApiIn1Out1(C.BHHeartbeat), data, reply, timeout_ms)
 }
 
 func HeartbeatEasy(timeout_ms int) bool {
@@ -133,24 +132,24 @@
 var cgoClientCB ClientCB
 var cgoSubDataCB SubDataCB
 
-//export CGoSubDataCallback
-func CGoSubDataCallback(cpid C.PCVoid, pid_len C.int, data C.PCVoid, data_len C.int) {
+//export cgoSubDataCallback
+func cgoSubDataCallback(cpid C.PCVoid, pid_len C.int, data C.PCVoid, data_len C.int) {
 	proc_id := string(C.GoBytes(unsafe.Pointer(cpid), pid_len))
 	msg := bh.MsgPublish{}
 	msg.Unmarshal(C.GoBytes(unsafe.Pointer(data), data_len))
 	cgoSubDataCB(&proc_id, &msg)
 }
 
-//export CGoServerCallback
-func CGoServerCallback(cpid C.PCVoid, pid_len C.int, data C.PCVoid, data_len C.int, src unsafe.Pointer) {
+//export cgoServerCallback
+func cgoServerCallback(cpid C.PCVoid, pid_len C.int, data C.PCVoid, data_len C.int, src unsafe.Pointer) {
 	proc_id := string(C.GoBytes(unsafe.Pointer(cpid), pid_len))
 	msg := bh.MsgRequestTopic{}
 	msg.Unmarshal(C.GoBytes(unsafe.Pointer(data), data_len))
 	cgoServerCB(src, &proc_id, &msg)
 }
 
-//export CGoClientCallback
-func CGoClientCallback(cpid C.PCVoid, pid_len C.int, msgid C.PCVoid, msgid_len C.int, data C.PCVoid, data_len C.int) {
+//export cgoClientCallback
+func cgoClientCallback(cpid C.PCVoid, pid_len C.int, msgid C.PCVoid, msgid_len C.int, data C.PCVoid, data_len C.int) {
 	proc_id := string(C.GoBytes(unsafe.Pointer(cpid), pid_len))
 	msg_id := C.GoBytes(unsafe.Pointer(msgid), msgid_len)
 	var msg bh.MsgRequestTopicReply
@@ -164,20 +163,3 @@
 	cgoSubDataCB = sub
 	C.CGoStartWorker()
 }
-
-/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-// user code:
-
-func ServerCallback(src unsafe.Pointer, proc_id *string, req *bh.MsgRequestTopic) {
-	fmt.Println("user server cb called, request topic: " + string(req.Topic) + ", data:" + string(req.Data))
-	reply := bh.MsgRequestTopicReply{}
-	reply.Data = []byte("reply 1234")
-	SendReply(src, &reply)
-}
-
-func SubDataCallback(proc_id *string, pub *bh.MsgPublish) {
-	fmt.Println("user sub data cb called")
-}
-func ClientCallback(proc_id *string, msg_id *[]byte, reply *bh.MsgRequestTopicReply) {
-	fmt.Println("user client cb reply: " + string(reply.Data))
-}
\ No newline at end of file
diff --git a/api/bhsgo/bhome_node_test.go b/api/bhsgo/bhome_node_test.go
index d4f4278..3629d89 100644
--- a/api/bhsgo/bhome_node_test.go
+++ b/api/bhsgo/bhome_node_test.go
@@ -5,8 +5,22 @@
 	"fmt"
 	"testing"
 	"time"
+	"unsafe"
 )
 
+func ServerCallback(src unsafe.Pointer, proc_id *string, req *bh.MsgRequestTopic) {
+	fmt.Println("user server cb called, request topic: " + string(req.Topic) + ", data:" + string(req.Data))
+	reply := bh.MsgRequestTopicReply{}
+	reply.Data = []byte("reply 1234")
+	SendReply(src, &reply)
+}
+
+func SubDataCallback(proc_id *string, pub *bh.MsgPublish) {
+	fmt.Println("user sub data cb called")
+}
+func ClientCallback(proc_id *string, msg_id *[]byte, reply *bh.MsgRequestTopicReply) {
+	fmt.Println("user client cb reply: " + string(reply.Data))
+}
 func TestRegister(t *testing.T) {
 	proc_id := "test_proc"
 	proc := bh.ProcInfo{}
@@ -20,6 +34,7 @@
 		fmt.Println("register ok")
 	} else {
 		fmt.Println("register failed")
+		t.Log("register error")
 		return
 	}
 
diff --git a/go.mod b/go.mod
index b7dcd0c..0e9701b 100644
--- a/go.mod
+++ b/go.mod
@@ -1,3 +1,5 @@
 module bhshmq
 
 go 1.14
+
+require github.com/gogo/protobuf v1.3.2 // indirect
diff --git a/go.sum b/go.sum
new file mode 100644
index 0000000..faf43b7
--- /dev/null
+++ b/go.sum
@@ -0,0 +1,31 @@
+github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
+github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
+github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
+github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
+github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
+golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
+golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
+golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
+golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
+golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
+golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
+golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
+golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=

--
Gitblit v1.8.0