Conan integration in CMake
This commit is contained in:
		
							
								
								
									
										20
									
								
								.cproject
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								.cproject
									
									
									
									
									
								
							| @@ -19,7 +19,7 @@ | |||||||
| 				</extensions> | 				</extensions> | ||||||
| 			</storageModule> | 			</storageModule> | ||||||
| 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | 			<storageModule moduleId="cdtBuildSystem" version="4.0.0"> | ||||||
| 				<configuration artifactName="${ProjName}" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.sharedLib" buildProperties="org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.sharedLib" description="" id="cdt.managedbuild.toolchain.gnu.base.2088633632" name="Debug" optionalBuildProperties="org.eclipse.cdt.docker.launcher.containerbuild.property.selectedvolumes=,org.eclipse.cdt.docker.launcher.containerbuild.property.volumes=" parent="org.eclipse.cdt.build.core.emptycfg"> | 				<configuration artifactName="${ProjName}" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.sharedLib" buildProperties="org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.sharedLib" description="" id="cdt.managedbuild.toolchain.gnu.base.2088633632" name="Debug" optionalBuildProperties="org.eclipse.cdt.docker.launcher.containerbuild.property.volumes=,org.eclipse.cdt.docker.launcher.containerbuild.property.selectedvolumes=" parent="org.eclipse.cdt.build.core.emptycfg"> | ||||||
| 					<folderInfo id="cdt.managedbuild.toolchain.gnu.base.2088633632.654284138" name="/" resourcePath=""> | 					<folderInfo id="cdt.managedbuild.toolchain.gnu.base.2088633632.654284138" name="/" resourcePath=""> | ||||||
| 						<toolChain id="cdt.managedbuild.toolchain.gnu.base.812439786" name="Linux GCC" nonInternalBuilderId="de.marw.cdt.cmake.core.genscriptbuilder" superClass="cdt.managedbuild.toolchain.gnu.base"> | 						<toolChain id="cdt.managedbuild.toolchain.gnu.base.812439786" name="Linux GCC" nonInternalBuilderId="de.marw.cdt.cmake.core.genscriptbuilder" superClass="cdt.managedbuild.toolchain.gnu.base"> | ||||||
| 							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.GNU_ELF;org.eclipse.cdt.core.ELF" id="cdt.managedbuild.target.gnu.platform.base.958806066" name="Debug Platform" osList="linux,hpux,aix,qnx" superClass="cdt.managedbuild.target.gnu.platform.base"/> | 							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.GNU_ELF;org.eclipse.cdt.core.ELF" id="cdt.managedbuild.target.gnu.platform.base.958806066" name="Debug Platform" osList="linux,hpux,aix,qnx" superClass="cdt.managedbuild.target.gnu.platform.base"/> | ||||||
| @@ -273,6 +273,22 @@ | |||||||
| 				<useDefaultCommand>true</useDefaultCommand> | 				<useDefaultCommand>true</useDefaultCommand> | ||||||
| 				<runAllBuilders>true</runAllBuilders> | 				<runAllBuilders>true</runAllBuilders> | ||||||
| 			</target> | 			</target> | ||||||
|  | 			<target name="all" path="" targetID="org.eclipse.cdt.build.MakeTargetBuilder"> | ||||||
|  | 				<buildCommand>CMAKE_BUILD_TOOL</buildCommand> | ||||||
|  | 				<buildArguments>$<cmake4eclipse_dyn></buildArguments> | ||||||
|  | 				<buildTarget>all</buildTarget> | ||||||
|  | 				<stopOnError>true</stopOnError> | ||||||
|  | 				<useDefaultCommand>true</useDefaultCommand> | ||||||
|  | 				<runAllBuilders>true</runAllBuilders> | ||||||
|  | 			</target> | ||||||
|  | 			<target name="VERBOSE=1" path="" targetID="org.eclipse.cdt.build.MakeTargetBuilder"> | ||||||
|  | 				<buildCommand>make</buildCommand> | ||||||
|  | 				<buildArguments/> | ||||||
|  | 				<buildTarget>VERBOSE=1</buildTarget> | ||||||
|  | 				<stopOnError>true</stopOnError> | ||||||
|  | 				<useDefaultCommand>false</useDefaultCommand> | ||||||
|  | 				<runAllBuilders>true</runAllBuilders> | ||||||
|  | 			</target> | ||||||
| 		</buildTargets> | 		</buildTargets> | ||||||
| 	</storageModule> | 	</storageModule> | ||||||
| </cproject> | </cproject> | ||||||
| @@ -5,7 +5,7 @@ | |||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
| 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | ||||||
| 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="-1471514668944563477" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1337717557877311424" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.gcc"/> | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.g++"/> | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
| 			</provider> | 			</provider> | ||||||
| @@ -18,7 +18,7 @@ | |||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
| 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | ||||||
| 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="-1471514668944563477" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1337717557877311424" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.gcc"/> | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.g++"/> | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
| 			</provider> | 			</provider> | ||||||
| @@ -30,7 +30,7 @@ | |||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
| 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | ||||||
| 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="-1471514668944563477" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1337717557877311424" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.gcc"/> | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.g++"/> | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
| 			</provider> | 			</provider> | ||||||
| @@ -43,7 +43,7 @@ | |||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/> | ||||||
| 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | 			<provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/> | ||||||
| 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | 			<provider copy-of="extension" id="org.eclipse.cdt.managedbuilder.core.GCCBuildCommandParser"/> | ||||||
| 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="-1471514668944563477" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | 			<provider class="org.eclipse.cdt.managedbuilder.language.settings.providers.GCCBuiltinSpecsDetector" console="false" env-hash="1337717557877311424" id="org.eclipse.cdt.managedbuilder.core.GCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD "${INPUTS}"" prefer-non-shared="true"> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.gcc"/> | 				<language-scope id="org.eclipse.cdt.core.gcc"/> | ||||||
| 				<language-scope id="org.eclipse.cdt.core.g++"/> | 				<language-scope id="org.eclipse.cdt.core.g++"/> | ||||||
| 			</provider> | 			</provider> | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| cmake_minimum_required(VERSION 3.12) | cmake_minimum_required(VERSION 3.12) | ||||||
| set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake ${CMAKE_CURRENT_SOURCE_DIR}/scc/cmake) | set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake ${CMAKE_CURRENT_SOURCE_DIR}/scc/cmake) | ||||||
|  | list(APPEND CMAKE_MODULE_PATH ${CMAKE_BINARY_DIR}) | ||||||
|  | list(APPEND CMAKE_PREFIX_PATH ${CMAKE_BINARY_DIR}) | ||||||
|  |  | ||||||
| project(SCC_Test) | project(SCC_Test) | ||||||
|  |  | ||||||
| @@ -16,20 +18,16 @@ get_info_from_git() | |||||||
| ### set the directory names of the submodules | ### set the directory names of the submodules | ||||||
| set(GIT_SUBMODULES scc) | set(GIT_SUBMODULES scc) | ||||||
| set(GIT_SUBMODULE_DIR_sc-components .) | set(GIT_SUBMODULE_DIR_sc-components .) | ||||||
| ### set each submodules's commit or tag that is to be checked out | ## set each submodules's commit or tag that is to be checked out | ||||||
| ### (leave empty if you want master) | ## (leave empty if you want master) | ||||||
| #set(GIT_SUBMODULE_VERSION_sc-components 3af6b9836589b082c19d9131c5d0b7afa8ddd7cd) |  | ||||||
| set(GIT_SUBMODULE_BRANCH_sc-components ${GIT_BRANCH}) | set(GIT_SUBMODULE_BRANCH_sc-components ${GIT_BRANCH}) | ||||||
|  |  | ||||||
| include(GNUInstallDirs) | include(GNUInstallDirs) | ||||||
| if(NOT NO_SUBMODULE_CHECK) | if(NOT NO_SUBMODULE_CHECK) | ||||||
| 	include(Submodules) | 	include(Submodules) | ||||||
| endif() | endif() | ||||||
| include(Conan) |  | ||||||
| include(BuildType) | include(BuildType) | ||||||
|  |  | ||||||
| #enable_testing()  |  | ||||||
|  |  | ||||||
| set(CMAKE_CXX_STANDARD 11) | set(CMAKE_CXX_STANDARD 11) | ||||||
| set(CMAKE_CXX_STANDARD_REQUIRED ON) | set(CMAKE_CXX_STANDARD_REQUIRED ON) | ||||||
| set(CMAKE_CXX_EXTENSIONS OFF) | set(CMAKE_CXX_EXTENSIONS OFF) | ||||||
| @@ -75,7 +73,56 @@ else() | |||||||
| endif() | endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| setup_conan(TARGETS) | ########################################################## | ||||||
|  | ## get conan packages | ||||||
|  | ########################################################## | ||||||
|  | include(ConanInline) | ||||||
|  |  | ||||||
|  | set(CONAN_BOOST_OPTIONS | ||||||
|  | boost:fPIC=True | ||||||
|  | boost:shared=True | ||||||
|  | boost:header_only=False  | ||||||
|  | boost:without_context=True | ||||||
|  | boost:without_contract=True | ||||||
|  | boost:without_coroutine=True | ||||||
|  | boost:without_fiber=True | ||||||
|  | boost:without_graph=True | ||||||
|  | boost:without_graph_parallel=True | ||||||
|  | boost:without_iostreams=True | ||||||
|  | boost:without_json=True | ||||||
|  | boost:without_locale=True | ||||||
|  | boost:without_log=True | ||||||
|  | boost:without_math=True | ||||||
|  | boost:without_mpi=True | ||||||
|  | boost:without_nowide=True | ||||||
|  | boost:without_python=True | ||||||
|  | boost:without_random=True | ||||||
|  | boost:without_regex=True | ||||||
|  | boost:without_stacktrace=True | ||||||
|  | boost:without_test=True | ||||||
|  | boost:without_timer=True | ||||||
|  | boost:without_type_erasure=True | ||||||
|  | boost:without_wave=True | ||||||
|  | ) | ||||||
|  | set(CONAN_PACKAGE_LIST fmt/6.1.2 boost/1.75.0 gsl-lite/0.37.0) | ||||||
|  | set(CONAN_PACKAGE_OPTIONS fmt:header_only=True ${CONAN_BOOST_OPTIONS}) | ||||||
|  | if(NOT DEFINED ENV{SYSTEMC_HOME}) | ||||||
|  |     set(CONAN_PACKAGE_LIST ${CONAN_PACKAGE_LIST} systemc/2.3.3 systemc-cci/1.0.0) | ||||||
|  |     set(CONAN_PACKAGE_OPTIONS ${CONAN_PACKAGE_OPTIONS} systemc-cci:shared=False) | ||||||
|  | endif() | ||||||
|  | conan_check() | ||||||
|  | conan_add_remote(NAME minres URL https://artifactory.minres.com/artifactory/api/conan/oss) | ||||||
|  | conan_cmake_configure(REQUIRES ${CONAN_PACKAGE_LIST} | ||||||
|  |                       GENERATORS cmake_find_package | ||||||
|  |                       OPTIONS ${CONAN_PACKAGE_OPTIONS} | ||||||
|  |                       ) | ||||||
|  |  | ||||||
|  | conan_install() | ||||||
|  | find_package(fmt) | ||||||
|  | find_package(gsl-lite) | ||||||
|  | find_package(SystemCLanguage) | ||||||
|  | find_package(systemc-cci) | ||||||
|  | ######################################################################################## | ||||||
|  |  | ||||||
| # This line finds the boost lib and headers.  | # This line finds the boost lib and headers.  | ||||||
| set(Boost_NO_BOOST_CMAKE ON) #  Don't do a find_package in config mode before searching for a regular boost install. | set(Boost_NO_BOOST_CMAKE ON) #  Don't do a find_package in config mode before searching for a regular boost install. | ||||||
|   | |||||||
| @@ -1,15 +0,0 @@ | |||||||
| [requires] |  | ||||||
|     fmt/6.1.2 |  | ||||||
|     boost/1.75.0 |  | ||||||
|     gsl-lite/0.37.0 |  | ||||||
|     systemc/2.3.3 |  | ||||||
|     #systemc-scv/2.0.1 |  | ||||||
|     systemc-cci/1.0.0 |  | ||||||
|  |  | ||||||
| [generators] |  | ||||||
|     cmake |  | ||||||
|  |  | ||||||
| [options] |  | ||||||
|     fmt:header_only=True |  | ||||||
| 	systemc:shared=True |  | ||||||
| 	systemc-cci:shared=True |  | ||||||
							
								
								
									
										2
									
								
								scc
									
									
									
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								scc
									
									
									
									
									
								
							 Submodule scc updated: 2a11251ae6...6d816e1c9a
									
								
							
		Reference in New Issue
	
	Block a user