зеркало из https://github.com/microsoft/git.git
Merge branch 'jh/simple-ipc-sans-pthread'
The "simple-ipc" did not compile without pthreads support, but the build procedure was not properly account for it. * jh/simple-ipc-sans-pthread: simple-ipc: correct ifdefs when NO_PTHREADS is defined
This commit is contained in:
Коммит
6aae0e2ad2
26
Makefile
26
Makefile
|
@ -1687,13 +1687,31 @@ ifdef NO_UNIX_SOCKETS
|
||||||
else
|
else
|
||||||
LIB_OBJS += unix-socket.o
|
LIB_OBJS += unix-socket.o
|
||||||
LIB_OBJS += unix-stream-server.o
|
LIB_OBJS += unix-stream-server.o
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Simple IPC requires threads and platform-specific IPC support.
|
||||||
|
# Only platforms that have both should include these source files
|
||||||
|
# in the build.
|
||||||
|
#
|
||||||
|
# On Windows-based systems, Simple IPC requires threads and Windows
|
||||||
|
# Named Pipes. These are always available, so Simple IPC support
|
||||||
|
# is optional.
|
||||||
|
#
|
||||||
|
# On Unix-based systems, Simple IPC requires pthreads and Unix
|
||||||
|
# domain sockets. So support is only enabled when both are present.
|
||||||
|
#
|
||||||
|
ifdef USE_WIN32_IPC
|
||||||
|
BASIC_CFLAGS += -DSUPPORTS_SIMPLE_IPC
|
||||||
|
LIB_OBJS += compat/simple-ipc/ipc-shared.o
|
||||||
|
LIB_OBJS += compat/simple-ipc/ipc-win32.o
|
||||||
|
else
|
||||||
|
ifndef NO_PTHREADS
|
||||||
|
ifndef NO_UNIX_SOCKETS
|
||||||
|
BASIC_CFLAGS += -DSUPPORTS_SIMPLE_IPC
|
||||||
LIB_OBJS += compat/simple-ipc/ipc-shared.o
|
LIB_OBJS += compat/simple-ipc/ipc-shared.o
|
||||||
LIB_OBJS += compat/simple-ipc/ipc-unix-socket.o
|
LIB_OBJS += compat/simple-ipc/ipc-unix-socket.o
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
ifdef USE_WIN32_IPC
|
|
||||||
LIB_OBJS += compat/simple-ipc/ipc-shared.o
|
|
||||||
LIB_OBJS += compat/simple-ipc/ipc-win32.o
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifdef NO_ICONV
|
ifdef NO_ICONV
|
||||||
|
|
|
@ -4,7 +4,13 @@
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
#include "thread-utils.h"
|
#include "thread-utils.h"
|
||||||
|
|
||||||
#ifdef SUPPORTS_SIMPLE_IPC
|
#ifndef SUPPORTS_SIMPLE_IPC
|
||||||
|
/*
|
||||||
|
* This source file should only be compiled when Simple IPC is supported.
|
||||||
|
* See the top-level Makefile.
|
||||||
|
*/
|
||||||
|
#error SUPPORTS_SIMPLE_IPC not defined
|
||||||
|
#endif
|
||||||
|
|
||||||
int ipc_server_run(const char *path, const struct ipc_server_opts *opts,
|
int ipc_server_run(const char *path, const struct ipc_server_opts *opts,
|
||||||
ipc_server_application_cb *application_cb,
|
ipc_server_application_cb *application_cb,
|
||||||
|
@ -24,5 +30,3 @@ int ipc_server_run(const char *path, const struct ipc_server_opts *opts,
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* SUPPORTS_SIMPLE_IPC */
|
|
||||||
|
|
|
@ -6,8 +6,12 @@
|
||||||
#include "unix-socket.h"
|
#include "unix-socket.h"
|
||||||
#include "unix-stream-server.h"
|
#include "unix-stream-server.h"
|
||||||
|
|
||||||
#ifdef NO_UNIX_SOCKETS
|
#ifndef SUPPORTS_SIMPLE_IPC
|
||||||
#error compat/simple-ipc/ipc-unix-socket.c requires Unix sockets
|
/*
|
||||||
|
* This source file should only be compiled when Simple IPC is supported.
|
||||||
|
* See the top-level Makefile.
|
||||||
|
*/
|
||||||
|
#error SUPPORTS_SIMPLE_IPC not defined
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
enum ipc_active_state ipc_get_active_state(const char *path)
|
enum ipc_active_state ipc_get_active_state(const char *path)
|
||||||
|
|
|
@ -4,8 +4,12 @@
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
#include "thread-utils.h"
|
#include "thread-utils.h"
|
||||||
|
|
||||||
#ifndef GIT_WINDOWS_NATIVE
|
#ifndef SUPPORTS_SIMPLE_IPC
|
||||||
#error This file can only be compiled on Windows
|
/*
|
||||||
|
* This source file should only be compiled when Simple IPC is supported.
|
||||||
|
* See the top-level Makefile.
|
||||||
|
*/
|
||||||
|
#error SUPPORTS_SIMPLE_IPC not defined
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int initialize_pipe_name(const char *path, wchar_t *wpath, size_t alloc)
|
static int initialize_pipe_name(const char *path, wchar_t *wpath, size_t alloc)
|
||||||
|
|
|
@ -252,8 +252,15 @@ endif()
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
|
if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
|
||||||
list(APPEND compat_SOURCES compat/simple-ipc/ipc-shared.c compat/simple-ipc/ipc-win32.c)
|
list(APPEND compat_SOURCES compat/simple-ipc/ipc-shared.c compat/simple-ipc/ipc-win32.c)
|
||||||
|
add_compile_definitions(SUPPORTS_SIMPLE_IPC)
|
||||||
|
set(SUPPORTS_SIMPLE_IPC 1)
|
||||||
else()
|
else()
|
||||||
|
# Simple IPC requires both Unix sockets and pthreads on Unix-based systems.
|
||||||
|
if(NOT NO_UNIX_SOCKETS AND NOT NO_PTHREADS)
|
||||||
list(APPEND compat_SOURCES compat/simple-ipc/ipc-shared.c compat/simple-ipc/ipc-unix-socket.c)
|
list(APPEND compat_SOURCES compat/simple-ipc/ipc-shared.c compat/simple-ipc/ipc-unix-socket.c)
|
||||||
|
add_compile_definitions(SUPPORTS_SIMPLE_IPC)
|
||||||
|
set(SUPPORTS_SIMPLE_IPC 1)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(EXE_EXTENSION ${CMAKE_EXECUTABLE_SUFFIX})
|
set(EXE_EXTENSION ${CMAKE_EXECUTABLE_SUFFIX})
|
||||||
|
@ -974,6 +981,7 @@ file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "X='${EXE_EXTENSION}'\n")
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "NO_GETTEXT='${NO_GETTEXT}'\n")
|
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "NO_GETTEXT='${NO_GETTEXT}'\n")
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "RUNTIME_PREFIX='${RUNTIME_PREFIX}'\n")
|
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "RUNTIME_PREFIX='${RUNTIME_PREFIX}'\n")
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "NO_PYTHON='${NO_PYTHON}'\n")
|
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "NO_PYTHON='${NO_PYTHON}'\n")
|
||||||
|
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "SUPPORTS_SIMPLE_IPC='${SUPPORTS_SIMPLE_IPC}'\n")
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "PATH=\"$PATH:$TEST_DIRECTORY/../compat/vcbuild/vcpkg/installed/x64-windows/bin\"\n")
|
file(APPEND ${CMAKE_BINARY_DIR}/GIT-BUILD-OPTIONS "PATH=\"$PATH:$TEST_DIRECTORY/../compat/vcbuild/vcpkg/installed/x64-windows/bin\"\n")
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -5,10 +5,6 @@
|
||||||
* See Documentation/technical/api-simple-ipc.txt
|
* See Documentation/technical/api-simple-ipc.txt
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(GIT_WINDOWS_NATIVE) || !defined(NO_UNIX_SOCKETS)
|
|
||||||
#define SUPPORTS_SIMPLE_IPC
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SUPPORTS_SIMPLE_IPC
|
#ifdef SUPPORTS_SIMPLE_IPC
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче