From fe569187669ffd58958b014ea3dc076c393255f5 Mon Sep 17 00:00:00 2001 From: Watson Date: Wed, 4 Oct 2023 15:48:17 +0900 Subject: [PATCH 1/2] Create release binary with cmake explicitly --- lib/mini_portile2/mini_portile_cmake.rb | 3 ++- test/test_cmake.rb | 9 ++++++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/lib/mini_portile2/mini_portile_cmake.rb b/lib/mini_portile2/mini_portile_cmake.rb index 8543645..fd7aa08 100644 --- a/lib/mini_portile2/mini_portile_cmake.rb +++ b/lib/mini_portile2/mini_portile_cmake.rb @@ -69,7 +69,8 @@ def cmake_compile_flags "-DCMAKE_SYSTEM_NAME=#{cmake_system_name}", "-DCMAKE_SYSTEM_PROCESSOR=#{cpu_type}", "-DCMAKE_C_COMPILER=#{c_compiler}", - "-DCMAKE_CXX_COMPILER=#{cxx_compiler}" + "-DCMAKE_CXX_COMPILER=#{cxx_compiler}", + "-DCMAKE_BUILD_TYPE=Release" ] end diff --git a/test/test_cmake.rb b/test/test_cmake.rb index c7bfb35..20abe75 100644 --- a/test/test_cmake.rb +++ b/test/test_cmake.rb @@ -96,7 +96,8 @@ def test_configure_defaults_with_macos "-DCMAKE_SYSTEM_NAME=Darwin", "-DCMAKE_SYSTEM_PROCESSOR=arm64", "-DCMAKE_C_COMPILER=some-host-clang", - "-DCMAKE_CXX_COMPILER=some-host-clang++" + "-DCMAKE_CXX_COMPILER=some-host-clang++", + "-DCMAKE_BUILD_TYPE=Release" ], recipe.configure_defaults) end @@ -119,7 +120,8 @@ def test_configure_defaults_with_manual_system_name "-DCMAKE_SYSTEM_NAME=Custom", "-DCMAKE_SYSTEM_PROCESSOR=x86_64", "-DCMAKE_C_COMPILER=gcc", - "-DCMAKE_CXX_COMPILER=g++" + "-DCMAKE_CXX_COMPILER=g++", + "-DCMAKE_BUILD_TYPE=Release" ], recipe.configure_defaults) end @@ -227,7 +229,8 @@ def default_x86_compile_flags "-DCMAKE_SYSTEM_NAME=Linux", "-DCMAKE_SYSTEM_PROCESSOR=x86_64", "-DCMAKE_C_COMPILER=gcc", - "-DCMAKE_CXX_COMPILER=g++" + "-DCMAKE_CXX_COMPILER=g++", + "-DCMAKE_BUILD_TYPE=Release" ] end From d2a6035109dfa8cd77c3069658a710c6c6ae15ab Mon Sep 17 00:00:00 2001 From: Mike Dalessio Date: Tue, 10 Oct 2023 17:33:49 -0400 Subject: [PATCH 2/2] Add config param for CMAKE_BUILD_TYPE - default to "Release" - allow :cmake_build_type kwarg to the constructor - override everything with CMAKE_BUILD_TYPE env var --- lib/mini_portile2/mini_portile_cmake.rb | 7 ++++++- test/test_cmake.rb | 11 +++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/lib/mini_portile2/mini_portile_cmake.rb b/lib/mini_portile2/mini_portile_cmake.rb index fd7aa08..41e1ad1 100644 --- a/lib/mini_portile2/mini_portile_cmake.rb +++ b/lib/mini_portile2/mini_portile_cmake.rb @@ -11,6 +11,7 @@ def configure_prefix def initialize(name, version, **kwargs) super(name, version, **kwargs) @cmake_command = kwargs[:cmake_command] + @cmake_build_type = kwargs[:cmake_build_type] end def configure_defaults @@ -49,6 +50,10 @@ def cmake_cmd (ENV["CMAKE"] || @cmake_command || "cmake").dup end + def cmake_build_type + (ENV["CMAKE_BUILD_TYPE"] || @cmake_build_type || "Release").dup + end + private def generator_defaults @@ -70,7 +75,7 @@ def cmake_compile_flags "-DCMAKE_SYSTEM_PROCESSOR=#{cpu_type}", "-DCMAKE_C_COMPILER=#{c_compiler}", "-DCMAKE_CXX_COMPILER=#{cxx_compiler}", - "-DCMAKE_BUILD_TYPE=Release" + "-DCMAKE_BUILD_TYPE=#{cmake_build_type}", ] end diff --git a/test/test_cmake.rb b/test/test_cmake.rb index 20abe75..7a3483c 100644 --- a/test/test_cmake.rb +++ b/test/test_cmake.rb @@ -196,6 +196,17 @@ def test_cmake_command_configuration end end + def test_cmake_build_type_configuration + without_env("CMAKE_BUILD_TYPE") do + assert_equal("Release", MiniPortileCMake.new("test", "1.0.0").cmake_build_type) + assert_equal("xyzzy", MiniPortileCMake.new("test", "1.0.0", cmake_build_type: "xyzzy").cmake_build_type) + end + with_env("CMAKE_BUILD_TYPE"=>"Debug") do + assert_equal("Debug", MiniPortileCMake.new("test", "1.0.0").cmake_build_type) + assert_equal("Debug", MiniPortileCMake.new("test", "1.0.0", cmake_build_type: "xyzzy").cmake_build_type) + end + end + private def with_stubbed_target(os: 'linux', cpu: 'x86_64')