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

Add the completed std::experimental::filesystem implementation and tests. The implementation supports C++11 or newer. The TS is built as part of 'libc++experimental.a'. Users of the TS need to manually link this library. Building and testing the TS can be disabled using the CMake option '-DLIBCXX_ENABLE_FILESYSTEM=OFF'. Currently 'libc++experimental.a' is not installed by default. To turn on the installation of the library use '-DLIBCXX_INSTALL_EXPERIMENTAL_LIBRARY=ON'. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@273034 91177308-0d34-0410-b5e6-96231b3b80d8
51 lines
1.5 KiB
C++
51 lines
1.5 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03
|
|
|
|
// <experimental/filesystem>
|
|
|
|
// class file_status
|
|
|
|
// void type(file_type) noexcept;
|
|
// void permissions(perms) noexcept;
|
|
|
|
#include <experimental/filesystem>
|
|
#include <type_traits>
|
|
#include <cassert>
|
|
|
|
namespace fs = std::experimental::filesystem;
|
|
|
|
int main() {
|
|
using namespace fs;
|
|
|
|
file_status st;
|
|
|
|
// type test
|
|
{
|
|
static_assert(noexcept(st.type(file_type::regular)),
|
|
"operation must be noexcept");
|
|
static_assert(std::is_same<decltype(st.type(file_type::regular)), void>::value,
|
|
"operation must return void");
|
|
assert(st.type() != file_type::regular);
|
|
st.type(file_type::regular);
|
|
assert(st.type() == file_type::regular);
|
|
}
|
|
// permissions test
|
|
{
|
|
static_assert(noexcept(st.permissions(perms::owner_read)),
|
|
"operation must be noexcept");
|
|
static_assert(std::is_same<decltype(st.permissions(perms::owner_read)), void>::value,
|
|
"operation must return void");
|
|
assert(st.permissions() != perms::owner_read);
|
|
st.permissions(perms::owner_read);
|
|
assert(st.permissions() == perms::owner_read);
|
|
}
|
|
}
|