diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2018-08-07 14:59:07 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2018-08-07 19:32:10 +0200 |
commit | c2b4305349ca855c497904282db354de56c74842 (patch) | |
tree | 13ff2901d1ab491d930f81cee6fa49e5cff11577 /build2/target.hxx | |
parent | 7149c8eaeec3efcfc9da0f89c9ae979ff2c07fd5 (diff) |
Add support for default extension specification, trailing dot escaping
For example:
cxx{*}: extension = cxx
cxx{foo} # foo.cxx
cxx{foo.test} # foo.test (probably what we want...)
cxx{foo.test...} # foo.test.cxx (... is this)
cxx{foo..} # foo.
cxx{foo....} # foo..
cxx{foo.....} # error (must come in escape pair)
Diffstat (limited to 'build2/target.hxx')
-rw-r--r-- | build2/target.hxx | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/build2/target.hxx b/build2/target.hxx index db5de67..1249f5c 100644 --- a/build2/target.hxx +++ b/build2/target.hxx @@ -648,6 +648,21 @@ namespace build2 static const target_type static_type; public: + // Split the name leaf into target name (in place) and extension + // (returned). + // + static optional<string> + split_name (string&, const location&); + + // Combine the target name and extension into the name leaf. + // + // If the target type has the default extension, then "escape" the + // existing extension if any. + // + static void + combine_name (string&, const optional<string>&, bool default_extension); + + public: virtual ~target (); @@ -1704,7 +1719,9 @@ namespace build2 template <const char* ext> bool - target_pattern_fix (const target_type&, const scope&, string&, bool); + target_pattern_fix (const target_type&, const scope&, + string&, optional<string>&, const location&, + bool); // Get the extension from the variable or use the default if none set. If // the default is NULL, then return NULL. @@ -1715,7 +1732,9 @@ namespace build2 template <const char* var, const char* def> bool - target_pattern_var (const target_type&, const scope&, string&, bool); + target_pattern_var (const target_type&, const scope&, + string&, optional<string>&, const location&, + bool); // Always return NULL extension. // |