X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Farchitecture.cpp;h=3905f40c872dcb7f04e6c05ed72a970dde31f2dd;hb=df88e22a258f169b9505acb0cb8d0ba7e66af7b6;hp=fd31bcdbfd942a9ad05146d73e7dbb73fcecc38b;hpb=b58e16b078df97d8aabf64a8e4d0d8ce37ad3877;p=builder.git diff --git a/source/architecture.cpp b/source/architecture.cpp index fd31bcd..3905f40 100644 --- a/source/architecture.cpp +++ b/source/architecture.cpp @@ -41,6 +41,7 @@ const char *systems[] = { "linux", "freebsd", + "darwin", "windows", 0 }; @@ -116,7 +117,10 @@ Architecture::Architecture(Builder &b, const string &spec): } else { - sharedlib_patterns.push_back(Pattern("lib%.so")); + if(system=="darwin") + sharedlib_patterns.push_back(Pattern("lib%.dylib")); + else + sharedlib_patterns.push_back(Pattern("lib%.so")); staticlib_patterns.push_back(Pattern("lib%.a")); executable_patterns.push_back(Pattern("%")); } @@ -124,16 +128,17 @@ Architecture::Architecture(Builder &b, const string &spec): bool Architecture::match_name(const string &pattern) const { - vector parts = split(pattern, "-"); + bool negate = (pattern[0]=='!'); + vector parts = split(pattern.substr(negate), "-"); for(vector::const_iterator i=parts.begin(); i!=parts.end(); ++i) { string part = resolve_alias(*i); if((part=="32" && bits==32) || (part=="64" && bits==64)) ; else if(part!=type && part!=cpu && part!=system) - return false; + return negate; } - return true; + return !negate; } string Architecture::resolve_alias(const string &part) const