Merge fatalerror into utility.
[alexxy/gromacs.git] / src / testutils / testoptions.cpp
1 /*
2  *
3  *                This source code is part of
4  *
5  *                 G   R   O   M   A   C   S
6  *
7  *          GROningen MAchine for Chemical Simulations
8  *
9  * Written by David van der Spoel, Erik Lindahl, Berk Hess, and others.
10  * Copyright (c) 1991-2000, University of Groningen, The Netherlands.
11  * Copyright (c) 2001-2009, The GROMACS development team,
12  * check out http://www.gromacs.org for more information.
13
14  * This program is free software; you can redistribute it and/or
15  * modify it under the terms of the GNU General Public License
16  * as published by the Free Software Foundation; either version 2
17  * of the License, or (at your option) any later version.
18  *
19  * If you want to redistribute modifications, please consider that
20  * scientific software is very special. Version control is crucial -
21  * bugs must be traceable. We will be happy to consider code for
22  * inclusion in the official distribution, but derived work must not
23  * be called official GROMACS. Details are found in the README & COPYING
24  * files - if they are missing, get the official version at www.gromacs.org.
25  *
26  * To help us fund GROMACS development, we humbly ask that you cite
27  * the papers on the package - you can find them in the top README file.
28  *
29  * For more info, check our website at http://www.gromacs.org
30  */
31 /*! \internal \file
32  * \brief
33  * Implements functions in testoptions.h.
34  *
35  * \author Teemu Murtola <teemu.murtola@cbr.su.se>
36  * \ingroup module_testutils
37  */
38 #include "testoptions.h"
39
40 #include <cstdio>
41 #include <cstdlib>
42
43 #include <new>
44 #include <string>
45 #include <vector>
46
47 #include <boost/scoped_ptr.hpp>
48
49 #include "gromacs/options/cmdlineparser.h"
50 #include "gromacs/options/options.h"
51 #include "gromacs/utility/errorcodes.h"
52 #include "gromacs/utility/gmxassert.h"
53
54 #include "datapath.h"
55 #include "refdata.h"
56 #include "testexceptions.h"
57
58 static boost::scoped_ptr<std::vector<std::string> > s_commandLine;
59
60 namespace gmx
61 {
62 namespace test
63 {
64
65 void initTestUtils(const char *dataPath, int *argc, char *argv[])
66 {
67     if (dataPath != NULL)
68     {
69         setTestDataPath(dataPath);
70     }
71     initReferenceData(argc, argv);
72     try
73     {
74         boost::scoped_ptr<std::vector<std::string> > commandLine(
75                 new std::vector<std::string>());
76         for (int i = 0; i < *argc; ++i)
77         {
78             commandLine->push_back(argv[i]);
79         }
80         swap(commandLine, s_commandLine);
81     }
82     catch (const std::bad_alloc &)
83     {
84         std::fprintf(stderr, "Out of memory\n");
85         std::exit(1);
86     }
87     ::gmx::setFatalErrorHandler(NULL);
88 }
89
90 void parseTestOptions(Options *options)
91 {
92     GMX_RELEASE_ASSERT(s_commandLine.get() != NULL,
93                        "Test options not initialized");
94     try
95     {
96         CommandLineParser(options).parse(s_commandLine.get());
97         options->finish();
98     }
99     catch (const GromacsException &ex)
100     {
101         GMX_THROW_WRAPPER_TESTEXCEPTION(ex);
102     }
103 }
104
105 } // namespace test
106 } // namespace gmx