From b5245ba0499b83dff9d7d48e06addc12ca0e6953 Mon Sep 17 00:00:00 2001 From: Timo Koch <timo.koch@iws.uni-stuttgart.de> Date: Sat, 29 Oct 2016 01:52:05 +0200 Subject: [PATCH] [start] Put dumux message in its own header --- dumux/common/dumuxmessage.hh | 180 +++++++++++++++++++++++++++++++++++ dumux/common/start.hh | 168 +++----------------------------- 2 files changed, 191 insertions(+), 157 deletions(-) create mode 100644 dumux/common/dumuxmessage.hh diff --git a/dumux/common/dumuxmessage.hh b/dumux/common/dumuxmessage.hh new file mode 100644 index 0000000000..825857b3cf --- /dev/null +++ b/dumux/common/dumuxmessage.hh @@ -0,0 +1,180 @@ +// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- +// vi: set et ts=4 sw=4 sts=4: +/***************************************************************************** + * See the file COPYING for full copying permissions. * + * * + * This program is free software: you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation, either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program. If not, see <http://www.gnu.org/licenses/>. * + *****************************************************************************/ +/*! + * \file + * \brief Provides the class creating the famous dumux start and end messages + */ +#ifndef DUMUX_MESSAGE_HH +#define DUMUX_MESSAGE_HH + +#include <iostream> +#include <ctime> + +namespace Dumux +{ + +/*! + * \ingroup Start + * \brief Dumux start and end message. + */ +class DumuxMessage +{ + //! The current number of messages. Please adjust if you add one. + static const int nMessages_ = 11; + +public: + + /*! + * \brief Selects random messages to write out at the start and end of a simulation run. + * \param firstCall Indicates if it's the first call and we have to dice (simulation is starting). + */ + static void print(bool firstCall = false) + { + // initialize in case someone forgets to set first call + static int dice = 8; + + if(firstCall) + { + // roll the dice to decide which start message will be displayed + std::srand(std::time(0)); + dice = std::rand() % (nMessages_ + 1); + } + + std::cout << std::endl; + + switch (dice) + { + case 0: + if(firstCall) + std::cout << "Welcome aboard DuMuX airlines. Please fasten your seatbelts! " + << "Emergency exits are near the time integration." << std::endl; + else + std::cout << "We hope that you enjoyed simulating with us " << std::endl + << "and that you will choose us next time, too." << std::endl; + break; + case 1: + if(firstCall) + std::cout << "Let's get the cow off the ice." << std::endl; + else + std::cout << "DuMuX got the cow off the ice." << std::endl; + break; + case 2: + if(firstCall) + std::cout << "Science, my lad, is made up of mistakes, but they are " + << "mistakes which it is useful to make, because they lead little " + << "by little to the truth." << std::endl + << " - Jules Verne, A journey to the center of the earth" << std::endl; + else + std::cout << "[We see that] science is eminently perfectible, and that each theory has " + << "constantly to give way to a fresh one." << std::endl + << " - Jules Verne, Journey to the Center of the Earth" << std::endl; + + break; + case 3: + if(firstCall) + std::cout << "Wherever he saw a hole he always wanted to know the depth of it. " + << "To him this was important." << std::endl + << " - Jules Verne, A journey to the center of the earth" << std::endl; + else + std::cout << "We may brave human laws, but we cannot resist natural ones." << std::endl + << " - Jules Verne, 20,000 Leagues Under the Sea" << std::endl; + break; + case 4: + if(firstCall) + std::cout << "Silence - to delight Bernd." << std::endl; + else + std::cout << std::endl << std::endl; + break; + case 5: + std::cout << "Don't panic... !" << std::endl; + break; + case 6: + if(firstCall) + std::cout << "You idiot! You signed the order to destroy Earth!" << std::endl + << " - Douglas Adams, HGttG" << std::endl; + else + std::cout << "Marvin: I've been talking to the main computer." << std::endl + << "Arthur: And?" << std::endl + << "Marvin: It hates me." << std::endl + << " - Douglas Adams, HGttG" << std::endl; + break; + case 7: + if(firstCall) + std::cout << "In the beginning the Universe was created. This has made a lot of " + << "people very angry and has been widely regarded as a bad move.!" << std::endl + << " - Douglas Adams, HGttG " << std::endl; + else + std::cout << "Forty-two. I checked it very thoroughly, and that quite definitely is the answer. I think " + << "the problem, to be quite honest with you, is that you\'ve never actually known what the question is." << std::endl + << " - Douglas Adams, HGttG " << std::endl; + break; + case 8: + std::cout << " ## @@@@ @ @ @ @" << std::endl; + std::cout << " ### # @ @ @@ @@ @ " << std::endl; + std::cout << " ## # @ @ @ @ @ @ @ @ @ @ @" << std::endl; + std::cout << " ## # @ @ @ @ @ @ @ @ " << std::endl; + std::cout << " # # @@@@ @@@ @ @ @@@ " << std::endl; + std::cout << " # # " << std::endl; + std::cout << " # # " << std::endl; + std::cout << " # ## %%% " << std::setw(8) << std::right << DUMUX_VERSION << std::endl; + std::cout << " # ### % % %% %% " << std::endl; + std::cout << "#### #%%% %% %%%%% %%%%%%%%%%%%%%%%%" << std::endl; + break; + case 9: + std::cout << "### # # # # " << std::endl; + std::cout << "# # # # ## ## # # # " << std::endl; + std::cout << "# # # # # # # # # # # " << std::endl; + std::cout << "### ## # # ## " << std::endl; + std::cout << " " << std::endl; + std::cout << "Dune for Multi-{ Phase, " << std::endl; + std::cout << " Component, " << std::endl; + std::cout << " Scale, " << std::endl; + std::cout << " Physics, " << std::endl; + std::cout << " ...} flow and transport in porous media" << std::endl; + break; + case 10: + if(firstCall) + std::cout << "Elliot Carver: Mr. Jones, are we ready to release our new software?" << std::endl + << "Jones: Yes, sir. As requested, it's full of bugs, which means people will be forced to upgrade for years." << std::endl + << " - James Bond, Tomorrow Never Dies" << std::endl; + else + { + std::cout << "Elliot Carver: Outstanding." << std::endl + << " - James Bond, Tomorrow Never Dies" << std::endl; + } + break; + case 11: + if(firstCall) + std::cout << "Chuck Norris has successfully compiled DuMuX." << std::endl; + else + std::cout << "Chuck Norris has compiled DuMuX even two times in a row!" << std::endl; + break; + + // Note: If you add a case, you have to increase the number of messages (nMessages_ variable). + + default: // silence to delight Bernd + return; + } + std::cout << std::endl; + } +}; + +} // end namespace Dumux + +#endif diff --git a/dumux/common/start.hh b/dumux/common/start.hh index 57c73fef46..f9e420d3a0 100644 --- a/dumux/common/start.hh +++ b/dumux/common/start.hh @@ -34,9 +34,10 @@ #include <dune/alugrid/dgf.hh> #endif // HAVE_DUNE_ALUGRID -#include "propertysystem.hh" -#include "parameters.hh" -#include "valgrind.hh" +#include <dumux/common/propertysystem.hh> +#include <dumux/common/parameters.hh> +#include <dumux/common/valgrind.hh> +#include <dumux/common/dumuxmessage.hh> namespace Dumux { @@ -134,145 +135,6 @@ std::string usageTextBlock() "\n"; } -/*! - * \ingroup Start - * \brief Dumux start and end message. - * - * Selects random messages to write out at the start and end of a simulation run. - * \param start Indicates if the simulation is starting (=true) or ending (=false). - */ -void dumuxMessage_(bool start) -{ - static int dice_; - if(start) - { - std::srand(std::time(0)); - // roll the dice to decide which start message will be displayed: - dice_ = std::rand() % 12; // has to be n+1 - } - - - std::cout << "" << std::endl; - switch (dice_) - { - case 0: - if(start) - std::cout << "Welcome aboard DuMuX airlines. Please fasten your seatbelts! " - << "Emergency exits are near the time integration." << std::endl; - else - std::cout << "We hope that you enjoyed simulating with us " << std::endl - << "and that you will choose us next time, too." << std::endl; - break; - case 1: - if(start) - std::cout << "Let's get the cow off the ice." << std::endl; - else - std::cout << "DuMuX got the cow off the ice." << std::endl; - break; - case 2: - if(start) - std::cout << "Science, my lad, is made up of mistakes, but they are " - << "mistakes which it is useful to make, because they lead little " - << "by little to the truth." << std::endl - << " - Jules Verne, A journey to the center of the earth" << std::endl; - else - std::cout << "[We see that] science is eminently perfectible, and that each theory has " - << "constantly to give way to a fresh one." << std::endl - << " - Jules Verne, Journey to the Center of the Earth" << std::endl; - - break; - case 3: - if(start) - std::cout << "Wherever he saw a hole he always wanted to know the depth of it. " - << "To him this was important." << std::endl - << " - Jules Verne, A journey to the center of the earth" << std::endl; - else - std::cout << "We may brave human laws, but we cannot resist natural ones." << std::endl - << " - Jules Verne, 20,000 Leagues Under the Sea" << std::endl; - break; - case 4: - if(start) - std::cout << "Silence - to delight Bernd." << std::endl; - else - std::cout << "\n " << std::endl; - break; - case 5: - std::cout << "Don't panic... !" << std::endl; - break; - case 6: - if(start) - std::cout << "You idiot! You signed the order to destroy Earth!" << std::endl - << " - Douglas Adams, HGttG" << std::endl; - else - std::cout << "Marvin: I've been talking to the main computer.\n Arthur: And?" << std::endl - << "Marvin: It hates me." << std::endl - << " - Douglas Adams, HGttG" << std::endl; - break; - case 7: - if(start) - std::cout << "In the beginning the Universe was created. This has made a lot of " - << "people very angry and has been widely regarded as a bad move.!" << std::endl - << " - Douglas Adams, HGttG " << std::endl; - else - std::cout << "Forty-two. I checked it very thoroughly, and that quite definitely is the answer. I think " - << "the problem, to be quite honest with you, is that you\'ve never actually known what the question is." << std::endl - << " - Douglas Adams, HGttG " << std::endl; - break; - case 8: - std::cout << " ## @@@@ @ @ @ @" << std::endl; - std::cout << " ### # @ @ @@ @@ @ " << std::endl; - std::cout << " ## # @ @ @ @ @ @ @ @ @ @ @" << std::endl; - std::cout << " ## # @ @ @ @ @ @ @ @ " << std::endl; - std::cout << " # # @@@@ @@@ @ @ @@@ " << std::endl; - std::cout << " # # " << std::endl; - std::cout << " # # " << std::endl; - std::cout << " # ## %%% " << std::setw(8) << std::right << DUMUX_VERSION << std::endl; - std::cout << " # ### % % %% %% " << std::endl; - std::cout << "#### #%%% %% %%%%% %%%%%%%%%%%%%%%%%" << std::endl; - break; - case 9: - std::cout << "### # # # # " << std::endl; - std::cout << "# # # # ## ## # # # " << std::endl; - std::cout << "# # # # # # # # # # # " << std::endl; - std::cout << "### ## # # ## " << std::endl; - std::cout << " " << std::endl; - std::cout << "Dune for Multi-{ Phase, " << std::endl; - std::cout << " Component, " << std::endl; - std::cout << " Scale, " << std::endl; - std::cout << " Physics, " << std::endl; - std::cout << " ...} flow and transport in porous media" << std::endl; - break; - case 10: - if(start) - { - std::cout << "Elliot Carver: Mr. Jones, are we ready to release our new software?" << std::endl; - std::cout << "Jones: Yes, sir. As requested, it's full of bugs, which means people will be forced to upgrade for years." << std::endl; - std::cout << " - James Bond, Tomorrow Never Dies" << std::endl; - } - else - { - std::cout << "Elliot Carver: Outstanding." << std::endl; - std::cout << " - James Bond, Tomorrow Never Dies" << std::endl; - } - break; - case 11: - if(start) - { - std::cout << "Chuck Norris has successfully compiled DuMuX." << std::endl; - } - else - { - std::cout << "Chuck Norris has compiled DuMuX even two times in a row!" << std::endl; - } - break; - // Note: If you add a case, you have to increase the modulus at the beginning of this function! - - default: // silence to delight Bernd - return ; - } - std::cout << std::endl; -} - /*! * \ingroup Start * @@ -301,7 +163,7 @@ int start_(int argc, // print dumux start message if (mpiHelper.rank() == 0) - dumuxMessage_(true); + DumuxMessage::print(/*firstCall=*/true); //////////////////////////////////////////////////////////// // parse the command line arguments @@ -455,22 +317,14 @@ int start_(int argc, Problem problem(timeManager, GridCreator::grid().leafGridView()); timeManager.init(problem, restartTime, dt, tEnd, restart); timeManager.run(); - // print dumux end message - if (mpiHelper.rank() == 0) - dumuxMessage_(false); - if (printParams && mpiHelper.rank() == 0) { - Parameters::print<TypeTag>(); - } - - // check if a deprecated TypeTag has been used - Properties::TypeTagAncestors<TypeTag>::addAncestors(); - if (Properties::TypeTagAncestors<TypeTag>::contains("Decoupled")) + // print dumux end message and maybe the parameters + if (mpiHelper.rank() == 0) { - std::cout << "\nAt least one of the used TypeTags contains the " - << "deprecated name \"Decoupled\":" << std::endl; - Properties::TypeTagAncestors<TypeTag>::print(std::cout); - std::cout << "Please use \"Sequential\" instead." << std::endl; + DumuxMessage::print(/*firstCall=*/false); + + if (printParams) + Parameters::print<TypeTag>(); } return 0; -- GitLab