aboutsummaryrefslogtreecommitdiff
path: root/build2/target.hxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2018-08-07 14:59:07 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2018-08-07 14:59:07 +0200
commite4f41c7319261b9585bd501256664679457e1d9d (patch)
tree21ef10a30d932a3172080de2690c6e38d851d0e2 /build2/target.hxx
parent7149c8eaeec3efcfc9da0f89c9ae979ff2c07fd5 (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.hxx20
1 files changed, 18 insertions, 2 deletions
diff --git a/build2/target.hxx b/build2/target.hxx
index db5de67..127940a 100644
--- a/build2/target.hxx
+++ b/build2/target.hxx
@@ -648,6 +648,18 @@ 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.
+ //
+ static void
+ combine_name (string&, const optional<string>&);
+
+ public:
virtual
~target ();
@@ -1704,7 +1716,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>&,
+ bool);
// Get the extension from the variable or use the default if none set. If
// the default is NULL, then return NULL.
@@ -1715,7 +1729,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>&,
+ bool);
// Always return NULL extension.
//