X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Farchitecture.h;h=cec397f8a29e1968a598d83abc949088a64d51ed;hb=d1a42f852e58918708b5b0cbd90219f6a95aa75b;hp=5446c04235f3f0465fe64c93f62fc31ce6fdfc4e;hpb=003f12c8e9b3ae8bc00658a8763ebd593ac8c390;p=builder.git diff --git a/source/architecture.h b/source/architecture.h index 5446c04..cec397f 100644 --- a/source/architecture.h +++ b/source/architecture.h @@ -7,18 +7,17 @@ class Builder; -// XXX Add lib/exe prefix/suffix fields. Some archs may need multiple alternatives, how to handle this? +/** +Stores information about an architecture. This includes CPU type, model and +bitness and operating system. +*/ class Architecture { public: - class Loader: public Msp::DataFile::Loader + class Loader: public Msp::DataFile::ObjectLoader { - private: - Architecture &arch; - public: Loader(Architecture &); - Architecture &get_object() { return arch; } }; typedef std::list PatternList; @@ -39,6 +38,7 @@ private: public: Architecture(Builder &b, const std::string &spec); + const std::string &get_type() const { return type; } const std::string &get_name() const { return name; } const std::string &get_system() const { return system; } unsigned get_bits() const { return bits; } @@ -47,7 +47,6 @@ public: bool is_native() const { return native; } bool is_cross() const { return !cross_prefix.empty(); } - void set_cross_prefix(const std::string &); const std::string &get_cross_prefix() const { return cross_prefix; } const PatternList &get_shared_library_patterns() const { return sharedlib_patterns; } @@ -59,6 +58,4 @@ private: void parse_specification(const std::string &); }; -typedef std::map ArchMap; - #endif