From 9558c6d68946e90699d3ec4db1a85cb0811542e2 Mon Sep 17 00:00:00 2001 From: Manu343726 Date: Wed, 27 Jul 2016 12:30:59 +0200 Subject: [PATCH] Correctly add XCB components if no components are requested This commit fixes the FindXCB.cmake module for the case no components are requested. The previous version assigned `XCB_FIND_COMPONENTS` list to an empty variable name. I was lucky enough to catch the bug in a corner case where both `XCB_COMPONENTS` and `XCB_FIND_COMPONENTS` were empty and `set()` command failed, but note this awesome CMake language supports more annoying corner cases like `XCB_COMPONENTS` empty and `XCB_FIND_COMPONENTS` with two elements, which results in the following `set()` invocation: ``` cmake set(${XCB_FIND_COMPONENTS[0]} ${XCB_FIND_COMPONENTS[1]}) ``` So always beware of CMake secret charms... --- cmake/Modules/FindXCB.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmake/Modules/FindXCB.cmake b/cmake/Modules/FindXCB.cmake index d6914610..4915f723 100644 --- a/cmake/Modules/FindXCB.cmake +++ b/cmake/Modules/FindXCB.cmake @@ -68,7 +68,7 @@ IF(NOT WIN32) endif() ELSE() # Add component name to the component list - set(${XCB_COMPONENTS} ${XCB_FIND_COMPONENTS}) + set(XCB_COMPONENTS ${XCB_FIND_COMPONENTS}) ENDIF() # Loop through requested xcb components (does not contain xlib_xcb)