mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 20:29:39 +08:00

When I applied r356500 (https://reviews.llvm.org/D59152), I somehow deleted all of filesystem's tests. I will revert r356500 and re-apply it properly. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@356505 91177308-0d34-0410-b5e6-96231b3b80d8
62 lines
1.9 KiB
C++
62 lines
1.9 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03
|
|
|
|
// <filesystem>
|
|
|
|
// class file_status
|
|
|
|
// explicit file_status() noexcept;
|
|
// explicit file_status(file_type, perms prms = perms::unknown) noexcept;
|
|
|
|
#include "filesystem_include.hpp"
|
|
#include <type_traits>
|
|
#include <cassert>
|
|
|
|
#include "test_convertible.hpp"
|
|
|
|
|
|
int main(int, char**) {
|
|
using namespace fs;
|
|
// Default ctor
|
|
{
|
|
static_assert(std::is_nothrow_default_constructible<file_status>::value,
|
|
"The default constructor must be noexcept");
|
|
static_assert(test_convertible<file_status>(),
|
|
"The default constructor must not be explicit");
|
|
const file_status f;
|
|
assert(f.type() == file_type::none);
|
|
assert(f.permissions() == perms::unknown);
|
|
}
|
|
|
|
// Unary ctor
|
|
{
|
|
static_assert(std::is_nothrow_constructible<file_status, file_type>::value,
|
|
"This constructor must be noexcept");
|
|
static_assert(!test_convertible<file_status, file_type>(),
|
|
"This constructor must be explicit");
|
|
|
|
const file_status f(file_type::not_found);
|
|
assert(f.type() == file_type::not_found);
|
|
assert(f.permissions() == perms::unknown);
|
|
}
|
|
// Binary ctor
|
|
{
|
|
static_assert(std::is_nothrow_constructible<file_status, file_type, perms>::value,
|
|
"This constructor must be noexcept");
|
|
static_assert(!test_convertible<file_status, file_type, perms>(),
|
|
"This constructor must b explicit");
|
|
const file_status f(file_type::regular, perms::owner_read);
|
|
assert(f.type() == file_type::regular);
|
|
assert(f.permissions() == perms::owner_read);
|
|
}
|
|
|
|
return 0;
|
|
}
|