Louis Dionne 87dd51983c [libc++] Remove support for CloudABI, which has been abandoned
Based on https://github.com/NuxiNL/cloudlibc, it appears that the CloudABI
project has been abandoned. This patch removes a bunch of CloudABI specific
logic that had been added to support that platform.

Note that some knobs like LIBCXX_ENABLE_STDIN and LIBCXX_ENABLE_STDOUT
coud be useful in their own right, however those are currently broken.
If we want to re-add such knobs in the future, we can do it like we've
done it for localization & friends so that we can officially support
that configuration.

Differential Revision: https://reviews.llvm.org/D108637
2021-08-24 14:11:32 -04:00

57 lines
2.3 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
//
//===----------------------------------------------------------------------===//
// <string.h>
#include <string.h>
#include <type_traits>
#include "test_macros.h"
#ifndef NULL
#error NULL not defined
#endif
int main(int, char**)
{
size_t s = 0;
void* vp = 0;
const void* vpc = 0;
char* cp = 0;
const char* cpc = 0;
ASSERT_SAME_TYPE(void*, decltype(memcpy(vp, vpc, s)));
ASSERT_SAME_TYPE(void*, decltype(memmove(vp, vpc, s)));
ASSERT_SAME_TYPE(char*, decltype(strcpy(cp, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strncpy(cp, cpc, s)));
ASSERT_SAME_TYPE(char*, decltype(strcat(cp, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strncat(cp, cpc, s)));
ASSERT_SAME_TYPE(int, decltype(memcmp(vpc, vpc, s)));
ASSERT_SAME_TYPE(int, decltype(strcmp(cpc, cpc)));
ASSERT_SAME_TYPE(int, decltype(strncmp(cpc, cpc, s)));
ASSERT_SAME_TYPE(int, decltype(strcoll(cpc, cpc)));
ASSERT_SAME_TYPE(size_t, decltype(strxfrm(cp, cpc, s)));
ASSERT_SAME_TYPE(void*, decltype(memchr(vp, 0, s)));
ASSERT_SAME_TYPE(const void*, decltype(memchr(vpc, 0, s)));
ASSERT_SAME_TYPE(char*, decltype(strchr(cp, 0)));
ASSERT_SAME_TYPE(const char*, decltype(strchr(cpc, 0)));
ASSERT_SAME_TYPE(size_t, decltype(strcspn(cpc, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strpbrk(cp, cpc)));
ASSERT_SAME_TYPE(const char*, decltype(strpbrk(cpc, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strrchr(cp, 0)));
ASSERT_SAME_TYPE(const char*, decltype(strrchr(cpc, 0)));
ASSERT_SAME_TYPE(size_t, decltype(strspn(cpc, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strstr(cp, cpc)));
ASSERT_SAME_TYPE(const char*, decltype(strstr(cpc, cpc)));
ASSERT_SAME_TYPE(char*, decltype(strtok(cp, cpc)));
ASSERT_SAME_TYPE(void*, decltype(memset(vp, 0, s)));
ASSERT_SAME_TYPE(char*, decltype(strerror(0)));
ASSERT_SAME_TYPE(size_t, decltype(strlen(cpc)));
return 0;
}