PR libstdc++/84159 fix appending strings to paths
authorJonathan Wakely <jwakely@redhat.com>
Tue, 15 May 2018 12:07:09 +0000 (13:07 +0100)
committerJonathan Wakely <redi@gcc.gnu.org>
Tue, 15 May 2018 12:07:09 +0000 (13:07 +0100)
commit6cda876da273e36bb65f843a9bf39576258ebf19
tree7d4b3f2e2b2fc7b7fb1c963aa9aabb5b8659f94a
parente4a5135fe3cfc77a2f7ea8d2fc55a346ed711789
PR libstdc++/84159 fix appending strings to paths

The path::operator/=(const Source&) and path::append overloads were
still following the semantics of the Filesystem TS not C++17. Only
the path::operator/=(const path&) overload was correct.

This change adds more tests for path::operator/=(const path&) and adds
new tests to verify that the other append operations have equivalent
behaviour.

PR libstdc++/84159
* include/bits/fs_path.h (path::operator/=, path::append): Construct
temporary path before calling _M_append.
(path::_M_append): Change parameter to path and implement C++17
semantics.
* testsuite/27_io/filesystem/path/append/path.cc: Add helper function
and more examples from the standard.
* testsuite/27_io/filesystem/path/append/source.cc: New.
* testsuite/27_io/filesystem/path/decompose/filename.cc: Add comment.
* testsuite/27_io/filesystem/path/nonmember/append.cc: New.

From-SVN: r260255
libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/fs_path.h
libstdc++-v3/testsuite/27_io/filesystem/path/append/path.cc
libstdc++-v3/testsuite/27_io/filesystem/path/append/source.cc [new file with mode: 0644]
libstdc++-v3/testsuite/27_io/filesystem/path/decompose/filename.cc
libstdc++-v3/testsuite/27_io/filesystem/path/nonmember/append.cc [new file with mode: 0644]