Commit 0a7da733 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 362dbf6e
...@@ -41,6 +41,8 @@ cdef extern from "wcfs_misc.h" nogil: ...@@ -41,6 +41,8 @@ cdef extern from "wcfs_misc.h" nogil:
cdef extern from "wcfs_watchlink.h" nogil: cdef extern from "wcfs_watchlink.h" nogil:
cppclass WatchLink: cppclass WatchLink:
error close() error close()
#error recvReq(ctx, PinReq *rx_into)
pair[string, error] sendReq(ctx, const string &req)
ctypedef WatchLink *pWatchLink # https://github.com/cython/cython/issues/534 ctypedef WatchLink *pWatchLink # https://github.com/cython/cython/issues/534
...@@ -83,6 +85,20 @@ cdef class PyWatchLink: ...@@ -83,6 +85,20 @@ cdef class PyWatchLink:
raise RuntimeError(err.Error()) # XXX exc class? raise RuntimeError(err.Error()) # XXX exc class?
# XXX recvReq
def sendReq(PyWatchLink pywlink, ctx, string req): # -> reply(string)
with nogil:
_ = wlink_sendReq_pyexc(pywlink.wlink, ctx, req)
reply = _.first
err = _.second
if err != nil:
raise RuntimeError(err.Error()) # XXX -> Xpy(err) ? pyraiseIf(err) ?
return reply
cdef class PyPinReq: cdef class PyPinReq:
pass pass
...@@ -93,8 +109,11 @@ cdef class PyPinReq: ...@@ -93,8 +109,11 @@ cdef class PyPinReq:
cdef nogil: cdef nogil:
pair[pWatchLink, error] wcfs_openwatch_pyexc(WCFS *wcfs) except +topyexc:
return wcfs._openwatch()
error wlink_close_pyexc(WatchLink *wlink) except +topyexc: error wlink_close_pyexc(WatchLink *wlink) except +topyexc:
return wlink.close() return wlink.close()
pair[pWatchLink, error] wcfs_openwatch_pyexc(WCFS *wcfs) except +topyexc: pair[string, error] wlink_sendReq_pyexc(WatchLink *wlink, ctx, const string &req) except +topyexc:
return wcfs._openwatch() return wlink.sendReq(ctx, req)
...@@ -209,7 +209,7 @@ error WatchLink::_write(const string &pkt) { ...@@ -209,7 +209,7 @@ error WatchLink::_write(const string &pkt) {
// sendReq sends client -> server request and returns server reply. // sendReq sends client -> server request and returns server reply.
// XXX -> reply | None when EOF // XXX -> reply | None when EOF
tuple<string, error> WatchLink::sendReq(context::Context *ctx, const string &req) { pair<string, error> WatchLink::sendReq(context::Context *ctx, const string &req) {
WatchLink *wlink = this; WatchLink *wlink = this;
// XXX err ctx // XXX err ctx
...@@ -224,11 +224,11 @@ tuple<string, error> WatchLink::sendReq(context::Context *ctx, const string &req ...@@ -224,11 +224,11 @@ tuple<string, error> WatchLink::sendReq(context::Context *ctx, const string &req
rxq.recvs(&rx), // 1 rxq.recvs(&rx), // 1
}); });
if (_ == 0) if (_ == 0)
return make_tuple("", ctx->err()); return make_pair("", ctx->err());
// XXX check for EOF // XXX check for EOF
string reply = rx.to_string(); string reply = rx.to_string();
return make_tuple(reply, nil); return make_pair(reply, nil);
} }
tuple</*rxq*/chan<rxPkt>, error> WatchLink::_sendReq(context::Context *ctx, const string &req) { tuple</*rxq*/chan<rxPkt>, error> WatchLink::_sendReq(context::Context *ctx, const string &req) {
......
...@@ -88,7 +88,7 @@ public: ...@@ -88,7 +88,7 @@ public:
friend pair<WatchLink*, error> WCFS::_openwatch(); friend pair<WatchLink*, error> WCFS::_openwatch();
error close(); error close();
error recvReq(context::Context *ctx, PinReq *rx_into); error recvReq(context::Context *ctx, PinReq *rx_into);
tuple<string, error> sendReq(context::Context *ctx, const string &req); pair<string, error> sendReq(context::Context *ctx, const string &req);
private: private:
void _closeTX(); void _closeTX();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment