Skip to content

Commit

Permalink
Enable 'prepare' for server task too. (#1686)
Browse files Browse the repository at this point in the history
  • Loading branch information
Barenboim authored Jan 13, 2025
1 parent 69eb2e1 commit 1c483da
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 11 deletions.
8 changes: 8 additions & 0 deletions src/factory/WFTask.h
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,12 @@ class WFNetworkTask : public CommRequest
}
}

public:
void set_prepare(std::function<void (WFNetworkTask<REQ, RESP> *)> prep)
{
this->prepare = std::move(prep);
}

public:
void set_callback(std::function<void (WFNetworkTask<REQ, RESP> *)> cb)
{
Expand All @@ -226,6 +232,7 @@ class WFNetworkTask : public CommRequest
int watch_timeo;
REQ req;
RESP resp;
std::function<void (WFNetworkTask<REQ, RESP> *)> prepare;
std::function<void (WFNetworkTask<REQ, RESP> *)> callback;

protected:
Expand Down Expand Up @@ -749,6 +756,7 @@ class WFRepeaterTask : public WFGenericTask
this->create = std::move(create);
}

public:
void set_callback(std::function<void (WFRepeaterTask *)> cb)
{
this->callback = std::move(cb);
Expand Down
22 changes: 11 additions & 11 deletions src/factory/WFTask.inl
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ class WFClientTask : public WFNetworkTask<REQ, RESP>
protected:
virtual CommMessageOut *message_out()
{
/* By using prepare function, users can modify request after
/* By using prepare function, users can modify the request after
* the connection is established. */
if (this->prepare)
this->prepare(this);
Expand Down Expand Up @@ -91,15 +91,6 @@ protected:
return series->pop();
}

public:
void set_prepare(std::function<void (WFNetworkTask<REQ, RESP> *)> prep)
{
this->prepare = std::move(prep);
}

protected:
std::function<void (WFNetworkTask<REQ, RESP> *)> prepare;

public:
WFClientTask(CommSchedObject *object, CommScheduler *scheduler,
std::function<void (WFNetworkTask<REQ, RESP> *)>&& cb) :
Expand All @@ -115,7 +106,16 @@ template<class REQ, class RESP>
class WFServerTask : public WFNetworkTask<REQ, RESP>
{
protected:
virtual CommMessageOut *message_out() { return &this->resp; }
virtual CommMessageOut *message_out()
{
/* By using prepare function, users can modify the response before
* replying to the client. */
if (this->prepare)
this->prepare(this);

return &this->resp;
}

virtual CommMessageIn *message_in() { return &this->req; }
virtual void handle(int state, int error);

Expand Down

0 comments on commit 1c483da

Please sign in to comment.