Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clean up CMake. #498

Merged
merged 7 commits into from
Mar 26, 2025
Merged

Conversation

OmniBlade
Copy link

Removed the #pragma comment linker instructions embedded in the code.
Removes the various alternate names for different libraries.
Refactors build types to all be options.
Cleans up presets so win32 can also be used as an msvc preset.
Moves compiler specific configuration to its own compilers.cmake file as much as possible.

Copy link

@xezon xezon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you plan to Merge with Rebase, please append (#498) to the commit titles.

@OmniBlade OmniBlade force-pushed the fixes/cleanup-cmake branch from beb4062 to 42515d3 Compare March 25, 2025 16:33
Copy link

@xezon xezon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks ok to me when the remaining linker error(s) are fixed.

Copy link

@DevGeniusCode DevGeniusCode left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I ran the default win32 and debug mode, all work properly including install.
There is a problem with vc6 in default mode with FetchContent, in debug mode it works fine.
VC6 also work fine.
I did not test int and prof

@DevGeniusCode DevGeniusCode added Build Anything related to building, compiling Generals Related Generals only ZeroHour Relates to Zero Hour labels Mar 25, 2025
@tintinhamans tintinhamans mentioned this pull request Mar 25, 2025
10 tasks
@tintinhamans tintinhamans linked an issue Mar 26, 2025 that may be closed by this pull request
10 tasks
@tintinhamans tintinhamans removed a link to an issue Mar 26, 2025
10 tasks
@OmniBlade OmniBlade force-pushed the fixes/cleanup-cmake branch 3 times, most recently from b3706fc to 06fe5e7 Compare March 26, 2025 10:44
@OmniBlade OmniBlade marked this pull request as ready for review March 26, 2025 10:55
Copy link

@xezon xezon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good.

Minor: I would have put some space after tag in commits:

[CMake]Move compiler configuration to its own cmake file.
       ^ space

So it does not look as cramped.

CMakeLists.txt Outdated
# Because we set CMAKE_CXX_STANDARD_REQUIRED and CMAKE_CXX_EXTENSIONS in the compilers.cmake this should be enforced.
target_compile_features(gz_config INTERFACE cxx_std_20)
endif()

target_compile_options(gz_config INTERFACE ${GENZH_FLAGS})

target_compile_definitions(gz_config INTERFACE $<IF:$<CONFIG:Debug>,_DEBUG WWDEBUG DEBUG,_RELEASE>)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps gz_config can also be moved into a config.cmake in a future change.

@OmniBlade OmniBlade force-pushed the fixes/cleanup-cmake branch from 06fe5e7 to 693a006 Compare March 26, 2025 11:07
tintinhamans pushed a commit to tintinhamans/GeneralsGameCode that referenced this pull request Mar 26, 2025
)

Files cause issues on 64bit and aren't required.
@OmniBlade OmniBlade requested a review from DevGeniusCode March 26, 2025 13:15
@OmniBlade OmniBlade force-pushed the fixes/cleanup-cmake branch from 09770a8 to 29eb00e Compare March 26, 2025 13:55
@OmniBlade OmniBlade requested a review from xezon March 26, 2025 13:57
Files cause issues on 64bit and aren't required.
GENZH_BUILD_%GAME%_TOOLS now defaults to ON and builds only tools a developer would use/need.
GENZH_BUILD_%GAME%_EXTRAS has been added and defaults to OFF. It controls building everything else.
All useful tools are now added to the install target.
@OmniBlade OmniBlade force-pushed the fixes/cleanup-cmake branch from 29eb00e to 8ca02a0 Compare March 26, 2025 14:57
@OmniBlade OmniBlade merged commit 45b45cb into TheSuperHackers:main Mar 26, 2025
9 checks passed
OmniBlade added a commit that referenced this pull request Mar 26, 2025
Cleans up sub library naming as libraries are now named based on target name and don't vary based on build options.
OmniBlade added a commit that referenced this pull request Mar 26, 2025
Files cause issues on 64bit and aren't required.
@OmniBlade OmniBlade deleted the fixes/cleanup-cmake branch March 26, 2025 15:38
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
…perHackers#498)

Cleans up sub library naming as libraries are now named based on target name and don't vary based on build options.
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
)

Files cause issues on 64bit and aren't required.
PiecePaperCode pushed a commit to PiecePaperCode/GeneralsGameCode that referenced this pull request Mar 28, 2025
GENZH_BUILD_%GAME%_TOOLS now defaults to ON and builds only tools a developer would use/need.
GENZH_BUILD_%GAME%_EXTRAS has been added and defaults to OFF. It controls building everything else.
All useful tools are now added to the install target.
@xezon xezon added this to the Code foundation build up milestone Mar 31, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Build Anything related to building, compiling Generals Related Generals only ZeroHour Relates to Zero Hour
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants