Remove dynamic exceptions
[anna.git] / include / anna / core / mt / ThreadManager.hpp
index 4e12c07..57eadb0 100644 (file)
@@ -1,37 +1,9 @@
-// ANNA - Anna is Not Nothingness Anymore
-//
-// (c) Copyright 2005-2014 Eduardo Ramos Testillano & Francisco Ruiz Rayo
-//
-// https://bitbucket.org/testillano/anna
-//
-// 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 Google Inc. 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 <Thread>::data(ii); }
+  static Thread* thread(thread_iterator ii) { return SafeRecycler <Thread>::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;
 };