Metric.h 4.06 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
///////////////////////////////////////////////////////////////////////////////
//
// File: Metric.h
//
// For more information, please see: http://www.nektar.info
//
// The MIT License
//
// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
// Department of Aeronautics, Imperial College London (UK), and Scientific
// Computing and Imaging Institute, University of Utah (USA).
//
// 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.
//
// Description: Definition of the metric base class.
//
///////////////////////////////////////////////////////////////////////////////

#ifndef NEKTAR_TESTS_METRIC_H
#define NEKTAR_TESTS_METRIC_H

38
#include <tinyxml.h>
39
#include <string>
40
#include <map>
41 42
#include <boost/filesystem.hpp>

Dave Moxey's avatar
Dave Moxey committed
43
#include <TestException.hpp>
44

45 46 47
namespace fs = boost::filesystem;

std::string PortablePath(const boost::filesystem::path& path);
48 49

namespace Nektar
50
{
51 52 53 54 55 56 57 58 59 60 61 62
    /**
     * @brief Check to see whether the given string @p s is empty (or null).
     */
    inline bool EmptyString(const char *s)
    {
        if (!s)
        {
            return true;
        }
        return std::string(s) == "";
    }

63 64 65
    class Metric
    {
    public:
66
        Metric(TiXmlElement *metric, bool generate);
67 68 69

        virtual ~Metric() = default;

70
        /// Perform the test, given the standard output and error streams
71 72 73
        bool Test     (std::istream& pStdout, std::istream& pStderr);
        /// Perform the test, given the standard output and error streams
        void Generate (std::istream& pStdout, std::istream& pStderr);
74 75 76 77 78 79 80 81 82 83
        /// Return metric type
        std::string GetType()
        {
            return m_type;
        }
        /// Return metric ID
        int GetID()
        {
            return m_id;
        }
Dave Moxey's avatar
Dave Moxey committed
84

85
    protected:
86
        /// Stores the ID of this metric.
87
        int m_id;
88 89
        /// Stores the type of this metric (uppercase).
        std::string m_type;
90
        /// Determines whether to generate this metric or not.
91
        bool m_generate;
92
        /// Pointer to XML structure containing metric definition.
93
        TiXmlElement *m_metric;
94 95

        virtual bool v_Test     (std::istream& pStdout,
96
                                 std::istream& pStderr) = 0;
97
        virtual void v_Generate (std::istream& pStdout,
98
                                 std::istream& pSrderr) = 0;
99 100 101
    };

    /// A shared pointer to an EquationSystem object
102
    typedef std::shared_ptr<Metric> MetricSharedPtr;
103

104 105
    /// Datatype of the NekFactory used to instantiate classes derived from the
    /// Advection class.
Dave Moxey's avatar
Dave Moxey committed
106
    class MetricFactory
107
    {
Dave Moxey's avatar
Dave Moxey committed
108
    public:
109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
        typedef MetricSharedPtr (*CreatorFunction)(TiXmlElement *, bool);

        std::string RegisterCreatorFunction(std::string key, CreatorFunction func)
        {
            m_map[key] = func;
            return key;
        }

        MetricSharedPtr CreateInstance(
            std::string key, TiXmlElement *elmt, bool generate)
        {
            return m_map[key](elmt, generate);
        }

    private:
        std::map<std::string, CreatorFunction> m_map;
    };
126

127
    MetricFactory& GetMetricFactory();
128
}
129 130

#endif