diff options
author | Volker Lendecke <vl@samba.org> | 2009-05-06 15:10:00 +0200 |
---|---|---|
committer | Volker Lendecke <vl@samba.org> | 2009-05-07 22:52:33 +0200 |
commit | b475a1e7ebfcc1e1e11800bf93893eae11966d05 (patch) | |
tree | 4e9abc90cfa71c7dc1e7ca94810aa36606640a87 /source3/lib/wbclient.c | |
parent | 6f320d0208be9e460af1bd10c0e42e78e17d53dc (diff) | |
download | samba-b475a1e7ebfcc1e1e11800bf93893eae11966d05.tar.gz samba-b475a1e7ebfcc1e1e11800bf93893eae11966d05.tar.bz2 samba-b475a1e7ebfcc1e1e11800bf93893eae11966d05.zip |
Convert lib/wb_reqtrans.c to unix calling conventions
Diffstat (limited to 'source3/lib/wbclient.c')
-rw-r--r-- | source3/lib/wbclient.c | 69 |
1 files changed, 61 insertions, 8 deletions
diff --git a/source3/lib/wbclient.c b/source3/lib/wbclient.c index c22e168454..abe5b50c43 100644 --- a/source3/lib/wbclient.c +++ b/source3/lib/wbclient.c @@ -20,6 +20,57 @@ #include "includes.h" #include "wbc_async.h" +wbcErr map_wbc_err_from_errno(int error) +{ + switch(error) { + case EPERM: + case EACCES: + return WBC_ERR_AUTH_ERROR; + case ENOMEM: + return WBC_ERR_NO_MEMORY; + case EIO: + default: + return WBC_ERR_UNKNOWN_FAILURE; + } +} + +bool tevent_req_is_wbcerr(struct tevent_req *req, wbcErr *pwbc_err) +{ + enum tevent_req_state state; + uint64_t error; + if (!tevent_req_is_error(req, &state, &error)) { + *pwbc_err = WBC_ERR_SUCCESS; + return false; + } + + switch (state) { + case TEVENT_REQ_USER_ERROR: + *pwbc_err = error; + break; + case TEVENT_REQ_TIMED_OUT: + *pwbc_err = WBC_ERR_UNKNOWN_FAILURE; + break; + case TEVENT_REQ_NO_MEMORY: + *pwbc_err = WBC_ERR_NO_MEMORY; + break; + default: + *pwbc_err = WBC_ERR_UNKNOWN_FAILURE; + break; + } + return true; +} + +wbcErr tevent_req_simple_recv_wbcerr(struct tevent_req *req) +{ + wbcErr wbc_err; + + if (tevent_req_is_wbcerr(req, &wbc_err)) { + return wbc_err; + } + + return WBC_ERR_SUCCESS; +} + struct wb_context { struct tevent_queue *queue; int fd; @@ -320,12 +371,13 @@ static void wb_int_trans_write_done(struct tevent_req *subreq) subreq, struct tevent_req); struct wb_int_trans_state *state = tevent_req_data( req, struct wb_int_trans_state); - wbcErr wbc_err; + ssize_t ret; + int err; - wbc_err = wb_req_write_recv(subreq); + ret = wb_req_write_recv(subreq, &err); TALLOC_FREE(subreq); - if (!WBC_ERROR_IS_OK(wbc_err)) { - tevent_req_error(req, wbc_err); + if (ret == -1) { + tevent_req_error(req, map_wbc_err_from_errno(err)); return; } @@ -342,12 +394,13 @@ static void wb_int_trans_read_done(struct tevent_req *subreq) subreq, struct tevent_req); struct wb_int_trans_state *state = tevent_req_data( req, struct wb_int_trans_state); - wbcErr wbc_err; + ssize_t ret; + int err; - wbc_err = wb_resp_read_recv(subreq, state, &state->wb_resp); + ret = wb_resp_read_recv(subreq, state, &state->wb_resp, &err); TALLOC_FREE(subreq); - if (!WBC_ERROR_IS_OK(wbc_err)) { - tevent_req_error(req, wbc_err); + if (ret == -1) { + tevent_req_error(req, map_wbc_err_from_errno(err)); return; } |