diff options
| author | Louis Dionne <ldionne@apple.com> | 2019-03-19 19:27:29 +0000 |
|---|---|---|
| committer | Louis Dionne <ldionne@apple.com> | 2019-03-19 19:27:29 +0000 |
| commit | f7b43230b844373b421571467864a5fbf644e38d (patch) | |
| tree | b5cd58d906a56409c2db98997f60f4d2020cbd47 /libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp | |
| parent | d81df259b3505ba892f2dec1818eada3fe4b56a6 (diff) | |
| download | bcm5719-llvm-f7b43230b844373b421571467864a5fbf644e38d.tar.gz bcm5719-llvm-f7b43230b844373b421571467864a5fbf644e38d.zip | |
Revert "[libc++] Build <filesystem> support as part of the dylib"
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.
llvm-svn: 356505
Diffstat (limited to 'libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp')
| -rw-r--r-- | libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp b/libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp new file mode 100644 index 00000000000..d60225d4ff6 --- /dev/null +++ b/libcxx/test/std/input.output/filesystems/fs.enum/enum.path.format.pass.cpp @@ -0,0 +1,39 @@ +//===----------------------------------------------------------------------===// +// +// 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 path; +// enum class format; + +#include "filesystem_include.hpp" +#include <type_traits> +#include <cassert> + +#include "test_macros.h" + +int main(int, char**) { + typedef fs::path::format E; + static_assert(std::is_enum<E>::value, ""); + + // Check that E is a scoped enum by checking for conversions. + typedef std::underlying_type<E>::type UT; + static_assert(!std::is_convertible<E, UT>::value, ""); + + LIBCPP_ONLY(static_assert(std::is_same<UT, unsigned char>::value, "")); // Implementation detail + + static_assert( + E::auto_format != E::native_format && + E::auto_format != E::generic_format && + E::native_format != E::generic_format, + "Expected enumeration values are not unique"); + + return 0; +} |

