diff options
author | Lioncash <[email protected]> | 2016-08-22 09:12:46 -0400 |
---|---|---|
committer | MerryMage <[email protected]> | 2016-08-22 15:55:39 +0100 |
commit | 1bedd3bd7f97ddd4904ab5280fcd947248b63ba9 (patch) | |
tree | 36c766d0377ba0c1d8eaecb7df5994ae6e2ed312 /CMakeModules | |
parent | 74246cc3bfcbe282890f13770f3778e5680244cb (diff) | |
download | dynarmic-1bedd3bd7f97ddd4904ab5280fcd947248b63ba9.tar.gz dynarmic-1bedd3bd7f97ddd4904ab5280fcd947248b63ba9.zip |
CMakeLists: Clean up
Moves functions out of the main CMakeLists file into module files that
can just be included whenever necessary. This also uses the CMake
provided variables for enforcing compiler requirements.
Diffstat (limited to 'CMakeModules')
-rw-r--r-- | CMakeModules/CreateDirectoryGroups.cmake | 15 | ||||
-rw-r--r-- | CMakeModules/DetectArchitecture.cmake | 16 |
2 files changed, 31 insertions, 0 deletions
diff --git a/CMakeModules/CreateDirectoryGroups.cmake b/CMakeModules/CreateDirectoryGroups.cmake new file mode 100644 index 00000000..e806421f --- /dev/null +++ b/CMakeModules/CreateDirectoryGroups.cmake @@ -0,0 +1,15 @@ +# This function should be passed a list of all files in a target. It will automatically generate +# file groups following the directory hierarchy, so that the layout of the files in IDEs matches the +# one in the filesystem. +function(create_directory_groups) + # Place any files that aren't in the source list in a separate group so that they don't get in + # the way. + source_group("Other Files" REGULAR_EXPRESSION ".") + + foreach(file_name ${ARGV}) + get_filename_component(dir_name "${file_name}" PATH) + # Group names use '\' as a separator even though the entire rest of CMake uses '/'... + string(REPLACE "/" "\\" group_name "${dir_name}") + source_group("${group_name}" FILES "${file_name}") + endforeach() +endfunction() diff --git a/CMakeModules/DetectArchitecture.cmake b/CMakeModules/DetectArchitecture.cmake new file mode 100644 index 00000000..e984c6b8 --- /dev/null +++ b/CMakeModules/DetectArchitecture.cmake @@ -0,0 +1,16 @@ +include(CheckSymbolExists) +function(detect_architecture symbol arch) + if (NOT DEFINED ARCHITECTURE) + set(CMAKE_REQUIRED_QUIET 1) + check_symbol_exists("${symbol}" "" ARCHITECTURE_${arch}) + unset(CMAKE_REQUIRED_QUIET) + + # The output variable needs to be unique across invocations otherwise + # CMake's crazy scope rules will keep it defined + if (ARCHITECTURE_${arch}) + set(ARCHITECTURE "${arch}" PARENT_SCOPE) + set(ARCHITECTURE_${arch} 1 PARENT_SCOPE) + add_definitions(-DARCHITECTURE_${arch}=1) + endif() + endif() +endfunction() |