mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-25 04:56:13 +08:00
Fix 3 bugs in filesystem tests and implementation.
This patch fixes the following bugs, all of which were discovered while testing a 32 bit build on a 64 bit machine. * path.itr/iterator.pass.cpp has undefined behavior. 'path::iterator' stashes the value of the element inside the iterator. This violates the BiDirIterator requirements but is allowed for path::iterator. However this means that using reverse_iterator<path::iterator> has undefined behavior because it assumes that 'Iter tmp = it; return *tmp' will not create a dangling reference. However it does, and this caused this particular test to fail. * path.native.obs/string_alloc.pass.cpp tested the SSO with a long string. On 32 bit builds std::wstring only has the SSO for strings of size 2. The test was using a string of size 4. * fs.op.space/space.pass.cpp had overflows while calculating the expected values. The fix here is to convert the statvfs data members to std::uintmax_t before multiplying them. The internal implementation already does this but the tests needed to do it as well. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@273078 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -30,7 +30,8 @@
|
||||
|
||||
namespace fs = std::experimental::filesystem;
|
||||
|
||||
MultiStringType shortString = MKSTR("abc");
|
||||
// the SSO is always triggered for strings of size 2.
|
||||
MultiStringType shortString = MKSTR("a");
|
||||
MultiStringType longString = MKSTR("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/123456789/abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ");
|
||||
|
||||
template <class CharT>
|
||||
@@ -43,8 +44,6 @@ void doShortStringTest(MultiStringType const& MS) {
|
||||
const path p((const char*)MS);
|
||||
{
|
||||
DisableAllocationGuard g;
|
||||
if (!std::is_same<CharT, char>::value)
|
||||
g.release();
|
||||
Str s = p.string<CharT>();
|
||||
assert(s == value);
|
||||
Str s2 = p.string<CharT>(Alloc{});
|
||||
@@ -55,6 +54,7 @@ void doShortStringTest(MultiStringType const& MS) {
|
||||
{
|
||||
using Traits = std::char_traits<CharT>;
|
||||
using AStr = std::basic_string<CharT, Traits, MAlloc>;
|
||||
DisableAllocationGuard g;
|
||||
AStr s = p.string<CharT, Traits, MAlloc>();
|
||||
assert(s == value);
|
||||
assert(MAlloc::alloc_count == 0);
|
||||
@@ -64,6 +64,7 @@ void doShortStringTest(MultiStringType const& MS) {
|
||||
{ // Other allocator - provided copy
|
||||
using Traits = std::char_traits<CharT>;
|
||||
using AStr = std::basic_string<CharT, Traits, MAlloc>;
|
||||
DisableAllocationGuard g;
|
||||
MAlloc a;
|
||||
// don't allow another allocator to be default constructed.
|
||||
MAlloc::disable_default_constructor = true;
|
||||
@@ -94,6 +95,7 @@ void doLongStringTest(MultiStringType const& MS) {
|
||||
{ // Other allocator - default construct
|
||||
using Traits = std::char_traits<CharT>;
|
||||
using AStr = std::basic_string<CharT, Traits, MAlloc>;
|
||||
DisableAllocationGuard g;
|
||||
AStr s = p.string<CharT, Traits, MAlloc>();
|
||||
assert(s == value);
|
||||
assert(MAlloc::alloc_count > 0);
|
||||
@@ -103,6 +105,7 @@ void doLongStringTest(MultiStringType const& MS) {
|
||||
{ // Other allocator - provided copy
|
||||
using Traits = std::char_traits<CharT>;
|
||||
using AStr = std::basic_string<CharT, Traits, MAlloc>;
|
||||
DisableAllocationGuard g;
|
||||
MAlloc a;
|
||||
// don't allow another allocator to be default constructed.
|
||||
MAlloc::disable_default_constructor = true;
|
||||
|
||||
Reference in New Issue
Block a user