Skip to content

Commit 749e90d

Browse files
committed
Rework build flags
Also cleanup CMake a bit and add install/uninstall targets CMake Caching is evil
1 parent 6527b8b commit 749e90d

8 files changed

+84
-31
lines changed

.gitignore

+2
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,9 @@ CMakeFiles/
3838
Testing/
3939
Makefile
4040
cmake_install.cmake
41+
cmake_uninstall.cmake
4142
CTestTestfile.cmake
43+
install_manifest.txt
4244
bin/
4345
lib/
4446
tags

CMakeLists.txt

+20-3
Original file line numberDiff line numberDiff line change
@@ -54,10 +54,11 @@ set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
5454
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
5555

5656
# Make the library
57+
option (BUILD_SHARED_LIBS "Build shared libraries instead of static libraries" OFF)
5758
add_library(clipboard ${HEADERS} ${SOURCE})
5859

5960
# Testing mode?
60-
set (test OFF CACHE BOOL "Enable libclipboard unit testing (default:off)")
61+
option (test "Enable libclipboard unit testing (default:off)" OFF)
6162
if (test)
6263
# gtest does not play well with pthreads and mingw
6364
if (MINGW)
@@ -67,14 +68,30 @@ if (test)
6768
# Runtime library conflicts
6869
set(gtest_force_shared_crt ON CACHE BOOL "Always use dynamic runtime library (default:on)" )
6970
endif()
70-
add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest)
71+
add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest EXCLUDE_FROM_ALL)
7172
enable_testing()
7273
include_directories(${gtest_SOURCE_DIR}/include ${gtest_SOURCE_DIR})
7374
add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/test)
7475
endif()
7576

7677
# Build sample executables?
77-
set (samples OFF CACHE BOOL "Build libclipboard sample executables (default:off)")
78+
option (samples "Build libclipboard sample executables (default:off)" OFF)
7879
if (samples)
7980
add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/samples)
8081
endif()
82+
83+
# Install options
84+
install(TARGETS clipboard
85+
RUNTIME DESTINATION bin
86+
LIBRARY DESTINATION lib
87+
ARCHIVE DESTINATION lib)
88+
install(FILES ${HEADERS} DESTINATION include)
89+
90+
# uninstall target
91+
configure_file(
92+
"${CMAKE_CURRENT_SOURCE_DIR}/cmake_uninstall.cmake.in"
93+
"${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
94+
IMMEDIATE @ONLY)
95+
96+
add_custom_target(uninstall
97+
COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake)

cmake_uninstall.cmake.in

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
if(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
2+
message(FATAL_ERROR "Cannot find install manifest: @CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
3+
endif(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
4+
5+
file(READ "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt" files)
6+
string(REGEX REPLACE "\n" ";" files "${files}")
7+
foreach(file ${files})
8+
message(STATUS "Uninstalling $ENV{DESTDIR}${file}")
9+
if(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
10+
exec_program(
11+
"@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\""
12+
OUTPUT_VARIABLE rm_out
13+
RETURN_VALUE rm_retval
14+
)
15+
if(NOT "${rm_retval}" STREQUAL 0)
16+
message(FATAL_ERROR "Problem when removing $ENV{DESTDIR}${file}")
17+
endif(NOT "${rm_retval}" STREQUAL 0)
18+
else(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
19+
message(STATUS "File $ENV{DESTDIR}${file} does not exist.")
20+
endif(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
21+
endforeach(file)

include/libclipboard.h

+20-6
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,26 @@
66
#ifndef _LIBCLIPBOARD_H_
77
#define _LIBCLIPBOARD_H_
88

9+
#if (defined(_WIN32) || defined(LIBCLIPBOARD_FORCE_WIN32)) && \
10+
!defined(LIBCLIPBOARD_FORCE_X11) && !defined(LIBCLIPBOARD_FORCE_COCOA)
11+
# define LIBCLIPBOARD_BUILD_WIN32
12+
#endif
13+
14+
#if (defined(__linux__) || defined(LIBCLIPBOARD_FORCE_X11)) && \
15+
!defined(LIBCLIPBOARD_FORCE_WIN32) && !defined(LIBCLIPBOARD_FORCE_COCOA)
16+
# define LIBCLIPBOARD_BUILD_X11
17+
#endif
18+
19+
#if (defined(__APPLE__) || defined(LIBCLIPBOARD_FORCE_COCOA)) && \
20+
!defined(LIBCLIPBOARD_FORCE_WIN32) && !defined(LIBCLIPBOARD_FORCE_X11)
21+
# define LIBCLIPBOARD_BUILD_COCOA
22+
#endif
23+
24+
#if !defined(LIBCLIPBOARD_BUILD_WIN32) && !defined(LIBCLIPBOARD_BUILD_X11) && \
25+
!defined(LIBCLIPBOARD_BUILD_COCOA)
26+
# error "Unsupported platform or invalid build flags"
27+
#endif
28+
929
#include <stdbool.h>
1030
#include <stdint.h>
1131

@@ -54,12 +74,6 @@ typedef struct clipboard_opts {
5474
/** Opaque data structure for a clipboard context/instance **/
5575
typedef struct clipboard_c clipboard_c;
5676

57-
#if !defined(_WIN32) && !defined(LIBCLIPBOARD_FORCE_WIN32) && \
58-
!defined(__linux__) && !defined(LIBCLIPBOARD_FORCE_X11) && \
59-
!defined(__APPLE__) && !defined(LIBCLIPBOARD_FORCE_COCOA)
60-
# error "Unsupported platform"
61-
#endif
62-
6377
/**
6478
* \brief Instantiates a new clipboard instance of the given type.
6579
*

src/clipboard_cocoa.c

+3-4
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,8 @@
33
* \brief OS X (Cocoa) implementation of the clipboard.
44
*/
55

6-
#if defined __APPLE__ || LIBCLIPBOARD_FORCE_COCOA
6+
#include "libclipboard.h"
7+
#ifdef LIBCLIPBOARD_BUILD_COCOA
78

89
#include "libclipboard.h"
910
#include <stdlib.h>
@@ -89,6 +90,4 @@ bool clipboard_set_text_ex(clipboard_c *cb, const char *src, int length, clipboa
8990
return ret;
9091
}
9192

92-
#else
93-
typedef int cocoa_dummy_define;
94-
#endif /* __APPLE__ || LIBCLIPBOARD_FORCE_COCOA */
93+
#endif /* LIBCLIPBOARD_BUILD_COCOA */

src/clipboard_win32.c

+4-4
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,9 @@
33
* \brief Windows implementation of the clipboard.
44
*/
55

6-
#if defined _WIN32 || LIBCLIPBOARD_FORCE_WIN32
6+
#include "libclipboard.h"
7+
8+
#ifdef LIBCLIPBOARD_BUILD_WIN32
79

810
#include "libclipboard.h"
911
#include <windows.h>
@@ -216,6 +218,4 @@ bool clipboard_set_text_ex(clipboard_c *cb, const char *src, int length, clipboa
216218
return true;
217219
}
218220

219-
#else
220-
typedef int win32_dummy_define;
221-
#endif /* _WIN32 || LIBCLIPBOARD_FORCE_WIN32 */
221+
#endif /* LIBCLIPBOARD_BUILD_WIN32 */

src/clipboard_x11.c

+3-5
Original file line numberDiff line numberDiff line change
@@ -5,10 +5,10 @@
55
* Blegh I hate X11
66
*/
77

8-
#if defined __linux__ || LIBCLIPBOARD_FORCE_X11
9-
108
#include "libclipboard.h"
119

10+
#ifdef LIBCLIPBOARD_BUILD_X11
11+
1212
#include <assert.h>
1313
#include <stdlib.h>
1414
#include <string.h>
@@ -665,6 +665,4 @@ bool clipboard_set_text_ex(clipboard_c *cb, const char *src, int length, clipboa
665665
return ret;
666666
}
667667

668-
#else
669-
typedef int x11_dummy_define;
670-
#endif /* __linux__ || LIBCLIPBOARD_FORCE_X11 */
668+
#endif /* LIBCLIPBOARD_BUILD_X11 */

test/test_basics.cpp

+11-9
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,14 @@
11
#include <gtest/gtest.h>
22
#include <libclipboard.h>
33
#include <vector>
4-
#include <thread>
5-
#include <chrono>
64
#include <iostream>
75

6+
#ifdef LIBCLIPBOARD_BUILD_X11
7+
#include <thread>
8+
#include <chrono>
89
using std::this_thread::sleep_for;
910
using std::chrono::milliseconds;
11+
#endif
1012

1113
class BasicsTest : public ::testing::Test {
1214
};
@@ -16,7 +18,7 @@ TEST_F(BasicsTest, TestInstantiation) {
1618
ASSERT_TRUE(ret != NULL);
1719
clipboard_free(ret);
1820
// TODO(jtanx): Insert platform specific tests based on clipboard_opts
19-
#ifdef _WIN32
21+
#ifdef LIBCLIPBOARD_BUILD_WIN32
2022
clipboard_opts opts = {0};
2123
ret = clipboard_new(&opts);
2224
ASSERT_TRUE(ret != NULL);
@@ -63,7 +65,7 @@ TEST_F(BasicsTest, TestOwnership) {
6365

6466
ASSERT_FALSE(clipboard_has_ownership(cb2, LC_CLIPBOARD));
6567
ASSERT_TRUE(clipboard_set_text_ex(cb2, "test2", -1, LC_CLIPBOARD));
66-
#ifdef __linux__
68+
#ifdef LIBCLIPBOARD_BUILD_X11
6769
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
6870
sleep_for(milliseconds(100));
6971
#endif
@@ -102,7 +104,7 @@ TEST_F(BasicsTest, TestSetText) {
102104
clipboard_c *cb2 = clipboard_new(NULL);
103105

104106
ASSERT_TRUE(clipboard_set_text_ex(cb1, "test", -1, LC_CLIPBOARD));
105-
#ifdef __linux__
107+
#ifdef LIBCLIPBOARD_BUILD_X11
106108
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
107109
sleep_for(milliseconds(100));
108110
#endif
@@ -114,7 +116,7 @@ TEST_F(BasicsTest, TestSetText) {
114116
free(ret2);
115117

116118
ASSERT_TRUE(clipboard_set_text_ex(cb2, "string", -1, LC_CLIPBOARD));
117-
#ifdef __linux__
119+
#ifdef LIBCLIPBOARD_BUILD_X11
118120
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
119121
sleep_for(milliseconds(100));
120122
#endif
@@ -126,7 +128,7 @@ TEST_F(BasicsTest, TestSetText) {
126128
free(ret2);
127129

128130
ASSERT_TRUE(clipboard_set_text_ex(cb1, "test", 1, LC_CLIPBOARD));
129-
#ifdef __linux__
131+
#ifdef LIBCLIPBOARD_BUILD_X11
130132
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
131133
sleep_for(milliseconds(100));
132134
#endif
@@ -152,7 +154,7 @@ TEST_F(BasicsTest, TestGetText) {
152154
ASSERT_TRUE(clipboard_text_ex(NULL, &length, LC_SELECTION) == NULL);
153155

154156
clipboard_set_text_ex(cb1, "test", -1, LC_CLIPBOARD);
155-
#ifdef __linux__
157+
#ifdef LIBCLIPBOARD_BUILD_X11
156158
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
157159
sleep_for(milliseconds(100));
158160
#endif
@@ -184,7 +186,7 @@ TEST_F(BasicsTest, TestUTF8InputOutput) {
184186
char *ret;
185187

186188
ASSERT_TRUE(clipboard_set_text_ex(cb1, "\xe6\x9c\xaa\xe6\x9d\xa5", -1, LC_CLIPBOARD));
187-
#ifdef __linux__
189+
#ifdef LIBCLIPBOARD_BUILD_X11
188190
/* Race condition on X11: SelectionClear/SelectionNotify event may come after */
189191
sleep_for(milliseconds(100));
190192
#endif

0 commit comments

Comments
 (0)