X-Git-Url: https://git.teslayout.com/public/public/public/?a=blobdiff_plain;f=include%2Fanna%2Fcore%2Fmt%2FThreadManager.hpp;h=57eadb031cf79cf4ffbb98c4eda66bbad0243278;hb=5a6cba5fde2b2f538a7515f8293cc0a8d9589dfa;hp=83cde93fb71a1c73c70cac9aeee25bc1d84fb169;hpb=39033fd99e58e994a5e98c1060dcc79e0d81f9c9;p=anna.git diff --git a/include/anna/core/mt/ThreadManager.hpp b/include/anna/core/mt/ThreadManager.hpp index 83cde93..57eadb0 100644 --- a/include/anna/core/mt/ThreadManager.hpp +++ b/include/anna/core/mt/ThreadManager.hpp @@ -1,37 +1,9 @@ -// ANNA - Anna is Not Nothingness Anymore -// -// (c) Copyright 2005-2014 Eduardo Ramos Testillano & Francisco Ruiz Rayo -// -// http://redmine.teslayout.com/projects/anna-suite -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions -// are met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of the copyright holder nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -// -// Authors: eduardo.ramos.testillano@gmail.com -// cisco.tierra@gmail.com +// ANNA - Anna is Not Nothingness Anymore // +// // +// (c) Copyright 2005-2015 Eduardo Ramos Testillano & Francisco Ruiz Rayo // +// // +// See project site at http://redmine.teslayout.com/projects/anna-suite // +// See accompanying file LICENSE or copy at http://www.teslayout.com/projects/public/anna.LICENSE // #ifndef anna_core_mt_ThreadManager_hpp @@ -98,7 +70,7 @@ public: * Devuelve el nombre asociado a este gestor. * \return el nombre asociado a este gestor. */ - const std::string& getName() const throw() { return a_name; } + const std::string& getName() const { return a_name; } /** Obtiene la instancia de un thread. El thread sólo se liberará de forma automática cuando se termine la ejecución del mismo. @@ -106,39 +78,39 @@ public: \warning Solo debe haber un único punto de creación de thread's por cada instancia de esta clase. */ - Thread* createThread() throw(RuntimeException); + Thread* createThread() noexcept(false); /** * Bloquea el proceso hasta que todos los threads lanzados por este gestor hayan terminado su ejecución. * \warning \li No debería invocarse desde un thread que haya sido creado por este gestor. * \li Los threads deberían crearse con el flag Thread::Flag::Joinable. */ - void join() throw(RuntimeException); + void join() noexcept(false); /** Devuelve un iterador al comienzo de la lista de threads. \return un iterador al comienzo de la lista de threads. */ - thread_iterator thread_begin() throw() { return begin(); } + thread_iterator thread_begin() { return begin(); } /** Devuelve un iterador al final de la lista de threads. \return un iterador al final de la lista de threads. */ - thread_iterator thread_end() throw() { return end(); } + thread_iterator thread_end() { return end(); } /** Devuelve el thread referenciado por el iterador recibido como parametro. \param ii Iterador. \return el thread referenciado por el iterador recibido como parametro. */ - static Thread* thread(thread_iterator ii) throw() { return SafeRecycler ::data(ii); } + static Thread* thread(thread_iterator ii) { return SafeRecycler ::data(ii); } /** * Devuelve una cadena con la información relevante sobre este gestor de threads * \return una cadena con la información relevante sobre este gestor de threads */ - std::string asString() const throw(); + std::string asString() const ; private: const std::string a_name; @@ -149,7 +121,7 @@ private: bool a_destroying; // Se invoca cuando el thread detecta que va a terminar y que tiene una factoria asociada. - void releaseThread(Thread* thread) throw(RuntimeException); + void releaseThread(Thread* thread) noexcept(false); friend class Thread; };