diff --git a/source/vibe/core/path.d b/source/vibe/core/path.d index 1c4acad..b3aa794 100644 --- a/source/vibe/core/path.d +++ b/source/vibe/core/path.d @@ -67,7 +67,7 @@ Path relativeTo(Path)(Path path, Path base_path) @safe enum up = Path.Segment2("..", Path.defaultSeparator); auto ret = Path(base_nodes.map!(p => up).chain(nodes)); if (path.endsWithSlash) { - if (ret.empty) return Path("." ~ path.toString()[$-1]); + if (ret.empty) return Path.fromTrustedString("." ~ path.toString()[$-1]); else ret.endsWithSlash = true; } return ret; @@ -142,6 +142,12 @@ unittest { } } +nothrow unittest { + auto p1 = PosixPath.fromTrustedString("/foo/bar/baz"); + auto p2 = PosixPath.fromTrustedString("/foo/baz/bam"); + assert(p2.relativeTo(p1).toString == "../../baz/bam"); +} + /** Computes the relative path to this path from `base_path` using web path rules. diff --git a/source/vibe/internal/hashmap.d b/source/vibe/internal/hashmap.d index 4a09df8..d803eb6 100644 --- a/source/vibe/internal/hashmap.d +++ b/source/vibe/internal/hashmap.d @@ -250,7 +250,7 @@ struct HashMap(TKey, TValue, Traits = DefaultHashMapTraits!TKey) } } -unittest { +nothrow unittest { import std.conv; HashMap!(string, string) map;