summaryrefslogtreecommitdiff
path: root/ext/dsent/util/Config.h
blob: 910f5ca8ca442f437a26bf86e3198e8f2f559a9a (plain)
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
38
39
40
#ifndef __DSENT_UTIL_CONFIG_H__
#define __DSENT_UTIL_CONFIG_H__

#include "util/CommonType.h"

namespace DSENT
{
    class TechModel;
    class StdCellLib;

    class Config : public LibUtil::Config
    {
        public:
            static void allocate(const String& cfg_file_name_);
            static void release();
            static Config* getSingleton();

        protected:
            static Config* ms_singleton_;

        public:
            Config();
            ~Config();

        public:
            void setTechModel(const TechModel* tech_model_);
            const TechModel* getTechModel() const;

            void constructTechModel(const String& overwrite_str_);

        protected:
            void readFile(const String& file_name_);

        protected:
            const TechModel* m_tech_model_;
    }; // class Config
} // namespace DSENT

#endif // __DSENT_UTIL_CONFIG_H__