| | |
| | | FUNASR_HANDLE& tpass_online_handle) {
|
| | | // lock for each connection
|
| | | scoped_lock guard(thread_lock);
|
| | | if(!tpass_online_handle){
|
| | | LOG(INFO) << "tpass_online_handle is free, return";
|
| | | return;
|
| | | }
|
| | | FUNASR_RESULT Result = nullptr;
|
| | | int asr_mode_ = 2;
|
| | | if (msg.contains("mode")) {
|
| | |
| | | std::make_shared<FUNASR_MESSAGE>(); // put a new data vector for new
|
| | | // connection
|
| | | data_msg->samples = std::make_shared<std::vector<char>>();
|
| | | data_msg->thread_lock = new websocketpp::lib::mutex();
|
| | | data_msg->thread_lock = std::make_shared<websocketpp::lib::mutex>(); |
| | |
|
| | | data_msg->msg = nlohmann::json::parse("{}");
|
| | | data_msg->msg["wav_format"] = "pcm";
|
| | |
| | | websocketpp::connection_hdl hdl,
|
| | | std::map<websocketpp::connection_hdl, std::shared_ptr<FUNASR_MESSAGE>,
|
| | | std::owner_less<websocketpp::connection_hdl>>& data_map) {
|
| | | // return;
|
| | | |
| | | std::shared_ptr<FUNASR_MESSAGE> data_msg = nullptr;
|
| | | auto it_data = data_map.find(hdl);
|
| | | if (it_data != data_map.end()) {
|
| | |
| | | FunTpassOnlineUninit(data_msg->tpass_online_handle);
|
| | | data_msg->tpass_online_handle = nullptr;
|
| | | }
|
| | | |
| | | |
| | | guard_decoder.unlock();
|
| | | delete data_msg->thread_lock;
|
| | | data_map.erase(hdl); // remove data vector when connection is closed
|
| | | }
|
| | |
|
| | |
| | | std::shared_ptr<std::vector<char>> sample_data_p = msg_data->samples;
|
| | | std::shared_ptr<std::vector<std::vector<std::string>>> punc_cache_p =
|
| | | msg_data->punc_cache;
|
| | | websocketpp::lib::mutex* thread_lock_p = msg_data->thread_lock;
|
| | | std::shared_ptr<websocketpp::lib::mutex> thread_lock_p = msg_data->thread_lock;
|
| | |
|
| | | lock.unlock();
|
| | |
|