summaryrefslogtreecommitdiffstats
path: root/stream.c
diff options
context:
space:
mode:
Diffstat (limited to 'stream.c')
-rw-r--r--stream.c32
1 files changed, 30 insertions, 2 deletions
diff --git a/stream.c b/stream.c
index 00b4f8d8..6c6a6e65 100644
--- a/stream.c
+++ b/stream.c
@@ -5016,16 +5016,44 @@ val dir_name(val path)
val short_suffix(val name, val alt_in)
{
+ const wchar_t *psc = coerce(const wchar_t *, path_sep_chars);
const wchar_t *str = c_str(name);
const wchar_t *dot = wcsrchr(str, '.');
- return if3(dot, string(dot + 1), default_null_arg(alt_in));
+ const wchar_t *sl = if3(dot, wcspbrk(dot + 1, psc), 0);
+
+ if (!dot || (sl && sl[1])) {
+ return default_null_arg(alt_in);
+ } else {
+ wchar_t *suff = chk_strdup(dot + 1);
+ if (sl)
+ suff[sl - (dot + 1)] = 0;
+ return string_own(suff);
+ }
}
val long_suffix(val name, val alt_in)
{
+ const wchar_t *psc = coerce(const wchar_t *, path_sep_chars);
const wchar_t *str = c_str(name);
const wchar_t *dot = wcschr(str, '.');
- return if3(dot, string(dot + 1), default_null_arg(alt_in));
+
+ {
+ const wchar_t *sl;
+
+ while (dot && (sl = wcspbrk(dot, psc)) && sl[1]) {
+ dot = wcschr(sl + 1, '.');
+ sl = wcspbrk(dot, psc);
+ }
+
+ if (!dot || (sl && sl[1])) {
+ return default_null_arg(alt_in);
+ } else {
+ wchar_t *suff = chk_strdup(dot + 1);
+ if (sl)
+ suff[sl - (dot + 1)] = 0;
+ return string_own(suff);
+ }
+ }
}
val path_cat(val dir_name, val base_name)