mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
cf93ecbbb2
The whole repository is now buildable with GNU Make Landlock sandboxing. This proves that no Makefile targets exist which touch files other than their declared prerequisites. In order to do this, we had to: 1. Stop code morphing GCC output in package.com and instead run a newly introduced FIXUPOBJ.COM command after GCC invocations. 2. Disable all the crumby Python unit tests that do things like create files in the current directory, or rename() files between folders. This ended up being a lot of tests, but most of them are still ok. 3. Introduce an .UNSANDBOXED variable to GNU Make to disable Landlock. We currently only do this for things like `make tags`. 4. This change deletes some GNU Make code that was preventing the execve() optimization from working. This means it should no longer be necessary in most cases for command invocations to be indirected through the cocmd interpreter. 5. Missing dependencies had to be declared in certain places, in cases where they couldn't be automatically determined by MKDEPS.COM 6. The libcxx header situation has finally been tamed. One of the things that makes this difficult is MKDEPS.COM only wants to consider the first 64kb of a file, in order to go fast. But libcxx likes to have #include lines buried after huge documentation. 7. An .UNVEIL variable has been introduced to GNU Make just in case we ever wish to explicitly specify additional things that need to be whitelisted which aren't strictly prerequisites. This works in a manner similar to the recently introduced .EXTRA_PREREQS feature. There's now a new build/bootstrap/make.com prebuilt binary available. It should no longer be possible to write invalid Makefile code.
140 lines
4.9 KiB
C++
140 lines
4.9 KiB
C++
// -*- C++ -*-
|
|
//===--------------------------- string.h ---------------------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef _LIBCPP_STRING_H
|
|
#define _LIBCPP_STRING_H
|
|
|
|
#include "third_party/libcxx/__config"
|
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
|
#pragma GCC system_header
|
|
#endif
|
|
|
|
#include "libc/str/str.h"
|
|
|
|
/*
|
|
string.h synopsis
|
|
|
|
Macros:
|
|
|
|
NULL
|
|
|
|
Types:
|
|
|
|
size_t
|
|
|
|
void* memcpy(void* restrict s1, const void* restrict s2, size_t n);
|
|
void* memmove(void* s1, const void* s2, size_t n);
|
|
char* strcpy (char* restrict s1, const char* restrict s2);
|
|
char* strncpy(char* restrict s1, const char* restrict s2, size_t n);
|
|
char* strcat (char* restrict s1, const char* restrict s2);
|
|
char* strncat(char* restrict s1, const char* restrict s2, size_t n);
|
|
int memcmp(const void* s1, const void* s2, size_t n);
|
|
int strcmp (const char* s1, const char* s2);
|
|
int strncmp(const char* s1, const char* s2, size_t n);
|
|
int strcoll(const char* s1, const char* s2);
|
|
size_t strxfrm(char* restrict s1, const char* restrict s2, size_t n);
|
|
const void* memchr(const void* s, int c, size_t n);
|
|
void* memchr( void* s, int c, size_t n);
|
|
const char* strchr(const char* s, int c);
|
|
char* strchr( char* s, int c);
|
|
size_t strcspn(const char* s1, const char* s2);
|
|
const char* strpbrk(const char* s1, const char* s2);
|
|
char* strpbrk( char* s1, const char* s2);
|
|
const char* strrchr(const char* s, int c);
|
|
char* strrchr( char* s, int c);
|
|
size_t strspn(const char* s1, const char* s2);
|
|
const char* strstr(const char* s1, const char* s2);
|
|
char* strstr( char* s1, const char* s2);
|
|
char* strtok(char* restrict s1, const char* restrict s2);
|
|
void* memset(void* s, int c, size_t n);
|
|
char* strerror(int errnum);
|
|
size_t strlen(const char* s);
|
|
|
|
*/
|
|
|
|
// MSVCRT, GNU libc and its derivates may already have the correct prototype in
|
|
// <string.h>. This macro can be defined by users if their C library provides
|
|
// the right signature.
|
|
#if defined(__CORRECT_ISO_CPP_STRING_H_PROTO) || defined(_LIBCPP_MSVCRT) || \
|
|
defined(__sun__) || defined(_STRING_H_CPLUSPLUS_98_CONFORMANCE_)
|
|
#define _LIBCPP_STRING_H_HAS_CONST_OVERLOADS
|
|
#endif
|
|
|
|
#if defined(__cplusplus) && !defined(_LIBCPP_STRING_H_HAS_CONST_OVERLOADS) && \
|
|
defined(_LIBCPP_PREFERRED_OVERLOAD)
|
|
extern "C++" {
|
|
inline _LIBCPP_INLINE_VISIBILITY char* __libcpp_strchr(const char* __s,
|
|
int __c) {
|
|
return (char*)strchr(__s, __c);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD const char*
|
|
strchr(const char* __s, int __c) {
|
|
return __libcpp_strchr(__s, __c);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD char*
|
|
strchr(char* __s, int __c) {
|
|
return __libcpp_strchr(__s, __c);
|
|
}
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY char* __libcpp_strpbrk(const char* __s1,
|
|
const char* __s2) {
|
|
return (char*)strpbrk(__s1, __s2);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD const char*
|
|
strpbrk(const char* __s1, const char* __s2) {
|
|
return __libcpp_strpbrk(__s1, __s2);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD char*
|
|
strpbrk(char* __s1, const char* __s2) {
|
|
return __libcpp_strpbrk(__s1, __s2);
|
|
}
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY char* __libcpp_strrchr(const char* __s,
|
|
int __c) {
|
|
return (char*)strrchr(__s, __c);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD const char*
|
|
strrchr(const char* __s, int __c) {
|
|
return __libcpp_strrchr(__s, __c);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD char*
|
|
strrchr(char* __s, int __c) {
|
|
return __libcpp_strrchr(__s, __c);
|
|
}
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY void* __libcpp_memchr(const void* __s, int __c,
|
|
size_t __n) {
|
|
return (void*)memchr(__s, __c, __n);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD const void*
|
|
memchr(const void* __s, int __c, size_t __n) {
|
|
return __libcpp_memchr(__s, __c, __n);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD void*
|
|
memchr(void* __s, int __c, size_t __n) {
|
|
return __libcpp_memchr(__s, __c, __n);
|
|
}
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY char* __libcpp_strstr(const char* __s1,
|
|
const char* __s2) {
|
|
return (char*)strstr(__s1, __s2);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD const char*
|
|
strstr(const char* __s1, const char* __s2) {
|
|
return __libcpp_strstr(__s1, __s2);
|
|
}
|
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD char*
|
|
strstr(char* __s1, const char* __s2) {
|
|
return __libcpp_strstr(__s1, __s2);
|
|
}
|
|
}
|
|
#endif
|
|
|
|
#endif // _LIBCPP_STRING_H
|