X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Farchitecture.h;h=c1446b462949c662eb5f0b117f315f38a42c83f3;hb=d914c5f40ca1194e7fd6a2b30664ac4717e38786;hp=2d7ca5f18c8f51017b82ecebc96f3b15c730d321;hpb=88a344b29ab173cd6ecacd0b038ea96dcb7484fc;p=builder.git diff --git a/source/architecture.h b/source/architecture.h index 2d7ca5f..c1446b4 100644 --- a/source/architecture.h +++ b/source/architecture.h @@ -26,8 +26,10 @@ private: Builder &builder; std::string type; std::string cpu; + std::string fpu; std::string system; unsigned bits; + std::string toolchain; std::string name; bool native; std::string cross_prefix; @@ -38,11 +40,15 @@ 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; } const std::string &get_cpu() const { return cpu; } + const std::string &get_fpu() const { return fpu; } + const std::string &get_toolchain() const { return toolchain; } bool match_name(const std::string &) const; + std::string best_match(const std::list &) const; bool is_native() const { return native; } bool is_cross() const { return !cross_prefix.empty(); } @@ -53,10 +59,8 @@ public: const PatternList &get_executable_patterns() const { return executable_patterns; } private: - std::string resolve_alias(const std::string &) const; + static void resolve_aliases(std::vector &); void parse_specification(const std::string &); }; -typedef std::map ArchMap; - #endif