2020-03-23 21:44:29 +08:00
|
|
|
#***************************************************************************
|
|
|
|
# _ _ ____ _
|
|
|
|
# Project ___| | | | _ \| |
|
|
|
|
# / __| | | | |_) | |
|
|
|
|
# | (__| |_| | _ <| |___
|
|
|
|
# \___|\___/|_| \_\_____|
|
|
|
|
#
|
2022-01-08 10:41:18 +08:00
|
|
|
# Copyright (C) 1998 - 2022, Daniel Stenberg, <daniel@haxx.se>, et al.
|
2020-03-23 21:44:29 +08:00
|
|
|
#
|
|
|
|
# This software is licensed as described in the file COPYING, which
|
|
|
|
# you should have received as part of this distribution. The terms
|
2020-11-04 21:02:01 +08:00
|
|
|
# are also available at https://curl.se/docs/copyright.html.
|
2020-03-23 21:44:29 +08:00
|
|
|
#
|
|
|
|
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
# copies of the Software, and permit persons to whom the Software is
|
|
|
|
# furnished to do so, under the terms of the COPYING file.
|
|
|
|
#
|
|
|
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
# KIND, either express or implied.
|
|
|
|
#
|
|
|
|
###########################################################################
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
include(CheckCSourceCompiles)
|
|
|
|
# The begin of the sources (macros and includes)
|
|
|
|
set(_source_epilogue "#undef inline")
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2009-06-10 01:29:16 +08:00
|
|
|
macro(add_header_include check header)
|
|
|
|
if(${check})
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
set(_source_epilogue "${_source_epilogue}\n#include <${header}>")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
|
|
|
endmacro()
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2009-06-10 01:29:16 +08:00
|
|
|
set(signature_call_conv)
|
|
|
|
if(HAVE_WINDOWS_H)
|
2009-04-02 21:14:53 +08:00
|
|
|
add_header_include(HAVE_WINSOCK2_H "winsock2.h")
|
2015-09-16 23:27:13 +08:00
|
|
|
add_header_include(HAVE_WINDOWS_H "windows.h")
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
set(_source_epilogue
|
|
|
|
"${_source_epilogue}\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif")
|
2009-06-10 01:29:16 +08:00
|
|
|
set(signature_call_conv "PASCAL")
|
2014-08-08 16:23:26 +08:00
|
|
|
if(HAVE_LIBWS2_32)
|
|
|
|
set(CMAKE_REQUIRED_LIBRARIES ws2_32)
|
|
|
|
endif()
|
2018-07-05 18:55:47 +08:00
|
|
|
else()
|
2009-04-02 21:14:53 +08:00
|
|
|
add_header_include(HAVE_SYS_TYPES_H "sys/types.h")
|
|
|
|
add_header_include(HAVE_SYS_SOCKET_H "sys/socket.h")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2019-04-07 18:43:38 +08:00
|
|
|
set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY)
|
|
|
|
|
2021-06-01 03:36:37 +08:00
|
|
|
function(curl_cv_func_recv_run_test recv_retv recv_arg1 recv_arg2 recv_arg3 recv_arg4)
|
|
|
|
unset(curl_cv_func_recv_test CACHE)
|
|
|
|
check_c_source_compiles("
|
|
|
|
${_source_epilogue}
|
|
|
|
#ifdef WINSOCK_API_LINKAGE
|
|
|
|
WINSOCK_API_LINKAGE
|
|
|
|
#endif
|
|
|
|
extern ${recv_retv} ${signature_call_conv}
|
|
|
|
recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4});
|
|
|
|
int main(void) {
|
|
|
|
${recv_arg1} s=0;
|
|
|
|
${recv_arg2} buf=0;
|
|
|
|
${recv_arg3} len=0;
|
|
|
|
${recv_arg4} flags=0;
|
|
|
|
${recv_retv} res = recv(s, buf, len, flags);
|
|
|
|
(void) res;
|
|
|
|
return 0;
|
|
|
|
}"
|
|
|
|
curl_cv_func_recv_test)
|
|
|
|
message(STATUS
|
|
|
|
"Tested: ${recv_retv} recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4})")
|
|
|
|
if(curl_cv_func_recv_test)
|
|
|
|
set(curl_cv_func_recv_args
|
|
|
|
"${recv_arg1},${recv_arg2},${recv_arg3},${recv_arg4},${recv_retv}" PARENT_SCOPE)
|
|
|
|
set(RECV_TYPE_ARG1 "${recv_arg1}" PARENT_SCOPE)
|
|
|
|
set(RECV_TYPE_ARG2 "${recv_arg2}" PARENT_SCOPE)
|
|
|
|
set(RECV_TYPE_ARG3 "${recv_arg3}" PARENT_SCOPE)
|
|
|
|
set(RECV_TYPE_ARG4 "${recv_arg4}" PARENT_SCOPE)
|
|
|
|
set(RECV_TYPE_RETV "${recv_retv}" PARENT_SCOPE)
|
|
|
|
set(HAVE_RECV 1 PARENT_SCOPE)
|
|
|
|
set(curl_cv_func_recv_done 1 PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void) {
|
|
|
|
recv(0, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}" curl_cv_recv)
|
2009-06-10 01:29:16 +08:00
|
|
|
if(curl_cv_recv)
|
2020-02-24 20:34:54 +08:00
|
|
|
if(NOT DEFINED curl_cv_func_recv_args OR curl_cv_func_recv_args STREQUAL "unknown")
|
2021-06-01 03:36:37 +08:00
|
|
|
if(APPLE)
|
|
|
|
curl_cv_func_recv_run_test("ssize_t" "int" "void *" "size_t" "int")
|
|
|
|
endif()
|
2009-06-10 01:29:16 +08:00
|
|
|
foreach(recv_retv "int" "ssize_t" )
|
2017-07-05 14:29:43 +08:00
|
|
|
foreach(recv_arg1 "SOCKET" "int" )
|
|
|
|
foreach(recv_arg2 "char *" "void *" )
|
|
|
|
foreach(recv_arg3 "int" "size_t" "socklen_t" "unsigned int")
|
2009-06-10 01:29:16 +08:00
|
|
|
foreach(recv_arg4 "int" "unsigned int")
|
|
|
|
if(NOT curl_cv_func_recv_done)
|
2021-06-01 03:36:37 +08:00
|
|
|
curl_cv_func_recv_run_test(${recv_retv} ${recv_arg1} ${recv_arg2} ${recv_arg3} ${recv_arg4})
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
else()
|
2009-06-10 01:29:16 +08:00
|
|
|
string(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG1 "${curl_cv_func_recv_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG2 "${curl_cv_func_recv_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG3 "${curl_cv_func_recv_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" RECV_TYPE_ARG4 "${curl_cv_func_recv_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" RECV_TYPE_RETV "${curl_cv_func_recv_args}")
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
endif()
|
2010-02-15 03:40:18 +08:00
|
|
|
|
2020-02-24 20:34:54 +08:00
|
|
|
if(curl_cv_func_recv_args STREQUAL "unknown")
|
2009-06-10 01:29:16 +08:00
|
|
|
message(FATAL_ERROR "Cannot find proper types to use for recv args")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
|
|
|
else()
|
2009-06-10 01:29:16 +08:00
|
|
|
message(FATAL_ERROR "Unable to link function recv")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
2009-06-10 01:29:16 +08:00
|
|
|
set(curl_cv_func_recv_args "${curl_cv_func_recv_args}" CACHE INTERNAL "Arguments for recv")
|
|
|
|
set(HAVE_RECV 1)
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2021-06-01 03:36:37 +08:00
|
|
|
function(curl_cv_func_send_run_test send_retv send_arg1 send_arg2 send_arg3 send_arg4)
|
|
|
|
unset(curl_cv_func_send_test CACHE)
|
|
|
|
check_c_source_compiles("
|
|
|
|
${_source_epilogue}
|
|
|
|
#ifdef WINSOCK_API_LINKAGE
|
|
|
|
WINSOCK_API_LINKAGE
|
|
|
|
#endif
|
|
|
|
extern ${send_retv} ${signature_call_conv}
|
|
|
|
send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4});
|
|
|
|
int main(void) {
|
|
|
|
${send_arg1} s=0;
|
|
|
|
${send_arg2} buf=0;
|
|
|
|
${send_arg3} len=0;
|
|
|
|
${send_arg4} flags=0;
|
|
|
|
${send_retv} res = send(s, buf, len, flags);
|
|
|
|
(void) res;
|
|
|
|
return 0;
|
|
|
|
}"
|
|
|
|
curl_cv_func_send_test)
|
|
|
|
message(STATUS
|
|
|
|
"Tested: ${send_retv} send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4})")
|
|
|
|
if(curl_cv_func_send_test)
|
|
|
|
string(REGEX REPLACE "(const) .*" "\\1" send_qual_arg2 "${send_arg2}")
|
|
|
|
string(REGEX REPLACE "const (.*)" "\\1" send_arg2 "${send_arg2}")
|
|
|
|
set(curl_cv_func_send_args
|
|
|
|
"${send_arg1},${send_arg2},${send_arg3},${send_arg4},${send_retv},${send_qual_arg2}" PARENT_SCOPE)
|
|
|
|
set(SEND_TYPE_ARG1 "${send_arg1}" PARENT_SCOPE)
|
|
|
|
set(SEND_TYPE_ARG2 "${send_arg2}" PARENT_SCOPE)
|
|
|
|
set(SEND_TYPE_ARG3 "${send_arg3}" PARENT_SCOPE)
|
|
|
|
set(SEND_TYPE_ARG4 "${send_arg4}" PARENT_SCOPE)
|
|
|
|
set(SEND_TYPE_RETV "${send_retv}" PARENT_SCOPE)
|
|
|
|
set(HAVE_SEND 1 PARENT_SCOPE)
|
|
|
|
set(curl_cv_func_send_done 1 PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void) {
|
|
|
|
send(0, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}" curl_cv_send)
|
2009-06-10 01:29:16 +08:00
|
|
|
if(curl_cv_send)
|
|
|
|
if(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown")
|
2021-06-01 03:36:37 +08:00
|
|
|
if(APPLE)
|
|
|
|
curl_cv_func_send_run_test("ssize_t" "int" "const void *" "size_t" "int")
|
|
|
|
endif()
|
2009-06-10 01:29:16 +08:00
|
|
|
foreach(send_retv "int" "ssize_t" )
|
2017-07-05 14:29:43 +08:00
|
|
|
foreach(send_arg1 "SOCKET" "int" "ssize_t" )
|
|
|
|
foreach(send_arg2 "const char *" "const void *" "void *" "char *")
|
|
|
|
foreach(send_arg3 "int" "size_t" "socklen_t" "unsigned int")
|
2009-06-10 01:29:16 +08:00
|
|
|
foreach(send_arg4 "int" "unsigned int")
|
|
|
|
if(NOT curl_cv_func_send_done)
|
2021-06-01 03:36:37 +08:00
|
|
|
curl_cv_func_send_run_test("${send_retv}" "${send_arg1}" "${send_arg2}" "${send_arg3}" "${send_arg4}")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
else()
|
2009-06-10 01:29:16 +08:00
|
|
|
string(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG1 "${curl_cv_func_send_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG2 "${curl_cv_func_send_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG3 "${curl_cv_func_send_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG4 "${curl_cv_func_send_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" SEND_TYPE_RETV "${curl_cv_func_send_args}")
|
|
|
|
string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" SEND_QUAL_ARG2 "${curl_cv_func_send_args}")
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
endif()
|
2010-02-15 03:40:18 +08:00
|
|
|
|
2009-06-10 01:29:16 +08:00
|
|
|
if("${curl_cv_func_send_args}" STREQUAL "unknown")
|
|
|
|
message(FATAL_ERROR "Cannot find proper types to use for send args")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
2009-06-10 01:29:16 +08:00
|
|
|
set(SEND_QUAL_ARG2 "const")
|
2018-07-05 18:55:47 +08:00
|
|
|
else()
|
2009-06-10 01:29:16 +08:00
|
|
|
message(FATAL_ERROR "Unable to link function send")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
2009-06-10 01:29:16 +08:00
|
|
|
set(curl_cv_func_send_args "${curl_cv_func_send_args}" CACHE INTERNAL "Arguments for send")
|
|
|
|
set(HAVE_SEND 1)
|
2009-04-02 21:14:53 +08:00
|
|
|
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void) {
|
|
|
|
int flag = MSG_NOSIGNAL;
|
|
|
|
(void)flag;
|
|
|
|
return 0;
|
|
|
|
}" HAVE_MSG_NOSIGNAL)
|
2009-04-02 21:14:53 +08:00
|
|
|
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
if(NOT HAVE_WINDOWS_H)
|
2009-04-02 21:14:53 +08:00
|
|
|
add_header_include(HAVE_SYS_TIME_H "sys/time.h")
|
|
|
|
add_header_include(TIME_WITH_SYS_TIME "time.h")
|
|
|
|
add_header_include(HAVE_TIME_H "time.h")
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
endif()
|
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void) {
|
|
|
|
struct timeval ts;
|
|
|
|
ts.tv_sec = 0;
|
|
|
|
ts.tv_usec = 0;
|
|
|
|
(void)ts;
|
|
|
|
return 0;
|
|
|
|
}" HAVE_STRUCT_TIMEVAL)
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2019-04-07 18:43:38 +08:00
|
|
|
if(HAVE_WINDOWS_H)
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES winsock2.h)
|
|
|
|
else()
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES)
|
|
|
|
if(HAVE_SYS_SOCKET_H)
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES sys/socket.h)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
check_type_size("struct sockaddr_storage" SIZEOF_STRUCT_SOCKADDR_STORAGE)
|
|
|
|
if(HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE)
|
|
|
|
set(HAVE_STRUCT_SOCKADDR_STORAGE 1)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
unset(CMAKE_TRY_COMPILE_TARGET_TYPE)
|
|
|
|
|
2019-01-15 17:50:18 +08:00
|
|
|
if(NOT DEFINED CMAKE_TOOLCHAIN_FILE)
|
2022-01-08 10:41:18 +08:00
|
|
|
if(NOT ${CMAKE_SYSTEM_NAME} MATCHES "Darwin" AND NOT ${CMAKE_SYSTEM_NAME} MATCHES "iOS")
|
|
|
|
# only try this on non-apple platforms
|
2021-08-23 22:39:33 +08:00
|
|
|
|
2019-01-15 17:50:18 +08:00
|
|
|
# if not cross-compilation...
|
|
|
|
include(CheckCSourceRuns)
|
|
|
|
set(CMAKE_REQUIRED_FLAGS "")
|
2016-10-31 07:45:17 +08:00
|
|
|
if(HAVE_SYS_POLL_H)
|
|
|
|
set(CMAKE_REQUIRED_FLAGS "-DHAVE_SYS_POLL_H")
|
2019-01-15 17:50:18 +08:00
|
|
|
elseif(HAVE_POLL_H)
|
|
|
|
set(CMAKE_REQUIRED_FLAGS "-DHAVE_POLL_H")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
2016-10-31 07:45:17 +08:00
|
|
|
check_c_source_runs("
|
2019-01-15 17:50:18 +08:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
2016-10-31 07:45:17 +08:00
|
|
|
#ifdef HAVE_SYS_POLL_H
|
|
|
|
# include <sys/poll.h>
|
2019-01-15 17:50:18 +08:00
|
|
|
#elif HAVE_POLL_H
|
|
|
|
# include <poll.h>
|
2016-10-31 07:45:17 +08:00
|
|
|
#endif
|
2019-01-15 17:50:18 +08:00
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
if(0 != poll(0, 0, 10)) {
|
|
|
|
return 1; /* fail */
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
/* detect the 10.12 poll() breakage */
|
|
|
|
struct timeval before, after;
|
|
|
|
int rc;
|
|
|
|
size_t us;
|
|
|
|
|
|
|
|
gettimeofday(&before, NULL);
|
|
|
|
rc = poll(NULL, 0, 500);
|
|
|
|
gettimeofday(&after, NULL);
|
|
|
|
|
|
|
|
us = (after.tv_sec - before.tv_sec) * 1000000 +
|
|
|
|
(after.tv_usec - before.tv_usec);
|
|
|
|
|
|
|
|
if(us < 400000) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
2016-10-31 07:45:17 +08:00
|
|
|
}" HAVE_POLL_FINE)
|
2021-08-23 22:39:33 +08:00
|
|
|
endif()
|
2016-10-31 07:45:17 +08:00
|
|
|
endif()
|
2009-04-02 21:14:53 +08:00
|
|
|
|