aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2018-07-30 11:15:58 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2018-07-30 11:15:58 +0200
commit6f120d5f670694a0d1bd8d9dd2a972c295e5daeb (patch)
treedcab1f48fcca53fc42c22e5c8548b065ad0a7c9e
parenta31945f682fc69340692680f2736aa74c186ef69 (diff)
Extend project_name::base() to optionally restrict extension
-rw-r--r--libbutl/project-name.cxx8
-rw-r--r--libbutl/project-name.mxx6
2 files changed, 12 insertions, 2 deletions
diff --git a/libbutl/project-name.cxx b/libbutl/project-name.cxx
index 5f94ea0..76a68b9 100644
--- a/libbutl/project-name.cxx
+++ b/libbutl/project-name.cxx
@@ -81,11 +81,17 @@ namespace butl
}
string project_name::
- base () const
+ base (const char* e) const
{
using std::string;
size_t p (path::traits::find_extension (value_));
+
+ if (e != nullptr &&
+ p != string::npos &&
+ casecmp (value_.c_str () + p + 1, e) != 0)
+ p = string::npos;
+
return string (value_, 0, p);
}
diff --git a/libbutl/project-name.mxx b/libbutl/project-name.mxx
index 6b5afc7..943ec8c 100644
--- a/libbutl/project-name.mxx
+++ b/libbutl/project-name.mxx
@@ -79,8 +79,12 @@ LIBBUTL_MODEXPORT namespace butl
// extension, then the base name is the same as the full name and the
// returned extension is empty.
//
+ // If the ext argument is not NULL, then only remove the specified
+ // extension. Note that the extension should not include the dot and the
+ // comparison is always case-insensitive.
+ //
std::string
- base () const;
+ base (const char* ext = nullptr) const;
std::string
extension () const;