/** * The MIT License (MIT) * * Copyright (c) 2013-2020 Winlin * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include #include #include #include #include using namespace std; SrsCoroutineManager::SrsCoroutineManager() { cond = srs_cond_new(); trd = new SrsSTCoroutine("manager", this); } SrsCoroutineManager::~SrsCoroutineManager() { srs_freep(trd); srs_cond_destroy(cond); clear(); } srs_error_t SrsCoroutineManager::start() { srs_error_t err = srs_success; if ((err = trd->start()) != srs_success) { return srs_error_wrap(err, "coroutine manager"); } return err; } srs_error_t SrsCoroutineManager::cycle() { srs_error_t err = srs_success; while (true) { if ((err = trd->pull()) != srs_success) { return srs_error_wrap(err, "coroutine mansger"); } srs_cond_wait(cond); clear(); } return err; } void SrsCoroutineManager::remove(ISrsConnection* c) { if (::find(conns.begin(), conns.end(), c) == conns.end()) { conns.push_back(c); } srs_cond_signal(cond); } void SrsCoroutineManager::clear() { // To prevent thread switch when delete connection, // we copy all connections then free one by one. vector copy; copy.swap(conns); vector::iterator it; for (it = copy.begin(); it != copy.end(); ++it) { ISrsConnection* conn = *it; srs_freep(conn); } }