Fix responses queue
This commit is contained in:
parent
6e10e6f012
commit
ffea9135e8
@ -88,11 +88,19 @@ class TdReceiver {
|
||||
Callback(MultiClient::ClientId client_id, TdReceiver *impl) : client_id_(client_id), impl_(impl) {
|
||||
}
|
||||
void on_result(uint64 id, td_api::object_ptr<td_api::Object> result) override {
|
||||
if (id == 0) {
|
||||
impl_->updates_.push({client_id_, 0, std::move(result)});
|
||||
} else {
|
||||
impl_->responses_.push({client_id_, id, std::move(result)});
|
||||
}
|
||||
}
|
||||
void on_error(uint64 id, td_api::object_ptr<td_api::error> error) override {
|
||||
if (id == 0) {
|
||||
impl_->updates_.push({client_id_, 0, std::move(error)});
|
||||
} else {
|
||||
impl_->responses_.push({client_id_, id, std::move(error)});
|
||||
}
|
||||
}
|
||||
Callback(const Callback &) = delete;
|
||||
Callback &operator=(const Callback &) = delete;
|
||||
Callback(Callback &&) = delete;
|
||||
@ -230,10 +238,10 @@ class Client::Impl final {
|
||||
class TdReceiver {
|
||||
public:
|
||||
TdReceiver() {
|
||||
output_updates_queue_ = std::make_shared<OutputQueue>();
|
||||
output_updates_queue_->init();
|
||||
output_responses_queue_ = std::make_shared<OutputQueue>();
|
||||
output_responses_queue_->init();
|
||||
output_updates_queue_ = std::make_shared<OutputQueue>();
|
||||
output_updates_queue_->init();
|
||||
}
|
||||
|
||||
MultiClient::Response receive(double timeout) {
|
||||
@ -254,15 +262,23 @@ class TdReceiver {
|
||||
unique_ptr<TdCallback> create_callback(MultiClient::ClientId client_id) {
|
||||
class Callback : public TdCallback {
|
||||
public:
|
||||
explicit Callback(MultiClient::ClientId client_id, std::shared_ptr<OutputQueue> output_updates_queue, std::shared_ptr<OutputQueue> output_responses_queue)
|
||||
: client_id_(client_id), output_updates_queue_(std::move(output_updates_queue)), output_responses_queue_(std::move(output_responses_queue)) {
|
||||
explicit Callback(MultiClient::ClientId client_id, std::shared_ptr<OutputQueue> output_responses_queue, std::shared_ptr<OutputQueue> output_updates_queue)
|
||||
: client_id_(client_id), output_responses_queue_(std::move(output_responses_queue), output_updates_queue_(std::move(output_updates_queue))) {
|
||||
}
|
||||
void on_result(uint64 id, td_api::object_ptr<td_api::Object> result) override {
|
||||
if (id == 0) {
|
||||
output_updates_queue_->writer_put({client_id_, 0, std::move(result)});
|
||||
} else {
|
||||
output_responses_queue_->writer_put({client_id_, id, std::move(result)});
|
||||
}
|
||||
}
|
||||
void on_error(uint64 id, td_api::object_ptr<td_api::error> error) override {
|
||||
if (id == 0) {
|
||||
output_updates_queue_->writer_put({client_id_, 0, std::move(error)});
|
||||
} else {
|
||||
output_responses_queue_->writer_put({client_id_, id, std::move(error)});
|
||||
}
|
||||
}
|
||||
Callback(const Callback &) = delete;
|
||||
Callback &operator=(const Callback &) = delete;
|
||||
Callback(Callback &&) = delete;
|
||||
@ -273,18 +289,18 @@ class TdReceiver {
|
||||
|
||||
private:
|
||||
MultiClient::ClientId client_id_;
|
||||
std::shared_ptr<OutputQueue> output_updates_queue_;
|
||||
std::shared_ptr<OutputQueue> output_responses_queue_;
|
||||
std::shared_ptr<OutputQueue> output_updates_queue_;
|
||||
};
|
||||
return td::make_unique<Callback>(client_id, output_updates_queue_, output_responses_queue_);
|
||||
return td::make_unique<Callback>(client_id, output_responses_queue_, output_updates_queue_);
|
||||
}
|
||||
|
||||
private:
|
||||
using OutputQueue = MpscPollableQueue<MultiClient::Response>;
|
||||
std::shared_ptr<OutputQueue> output_updates_queue_;
|
||||
std::shared_ptr<OutputQueue> output_responses_queue_;
|
||||
int output_updates_queue_ready_cnt_{0};
|
||||
std::shared_ptr<OutputQueue> output_updates_queue_;
|
||||
int output_responses_queue_ready_cnt_{0};
|
||||
int output_updates_queue_ready_cnt_{0};
|
||||
std::atomic<bool> receive_lock_{false};
|
||||
|
||||
MultiClient::Response receive_unlocked(double timeout, bool include_responses, bool include_updates) {
|
||||
|
Loading…
Reference in New Issue
Block a user