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

Compile with -fvisibility=hidden. #3322

Closed
wants to merge 1 commit into from

Conversation

teo-tsirpanis
Copy link

Fixes errors when spdlog is statically linked into two shared libraries, caused by the one copy calling a function of the other. This will not cause any problems for consumers because the exported APIs are already marked with SPDLOG_API.

Fixes errors when spdlog is statically linked into two shared libraries, caused by the one copy calling a function of the other. This will not cause any problems for consumers because the exported APIs are already marked with `SPDLOG_API`.
@tt4g
Copy link
Contributor

tt4g commented Jan 17, 2025

The user's project that is creating a custom sink must be using an API that is not publicly available with SPDLOG_API.
I do not think CMAKE_CXX_VISIBILITY_PRESET=hidden should be set in the spdlog project.

Instead, you should pass the -DCMAKE_CXX_VISIBILITY_PRESET=hidden option to the cmake command to achieve your goal.

@teo-tsirpanis
Copy link
Author

Which API is this, and why not also mark it with SPDLOG_API?

@tt4g
Copy link
Contributor

tt4g commented Jan 17, 2025

Some of the namespace details APIs are not publicly available.
However, we assume that some users are using them in custom sinks.

For example spdlog::details::circular_q: #2774 (comment)

@teo-tsirpanis
Copy link
Author

curcular_q is generic and thus will not be imported from a compiled library, and will not be affected by -fvisibility=hidden.

I looked at all headers that have an -inl.h counterpart, and the only API declaration that is defined in the -inl.h file and has not SPDLOG_API is this one:

void swap(logger &a, logger &b);

@tt4g
Copy link
Contributor

tt4g commented Jan 18, 2025

I'm concerned that some users may be using symbols that have not been exported in the constructors of custom sinks and function arguments and return values.
So it is my opinion that we should not set(CMAKE_CXX_VISIBILITY_PRESET hidden) in CMakeLists.txt of spdlog project.
And users who do not want to expose the spdlog symbols can hide them with cmake -DCMAKE_CXX_VISIBILITY_PRESET=hidden to hide the symbols, so your goal is achieved without any changes.

Finally, this is just my opinion.
@gabime is the one who makes the decision to merge.

@gabime
Copy link
Owner

gabime commented Jan 18, 2025

Agree with @tt4g — who knows what user code this might break. I'll add it to the v2.x branch since it's meant for breaking changes anyway.

@gabime gabime closed this Jan 18, 2025
@teo-tsirpanis teo-tsirpanis deleted the fvisibility-hidden branch January 18, 2025 10:58
@gabime
Copy link
Owner

gabime commented Jan 18, 2025

Merged to v2.x in PR #3324. It required some changes to ansicolor_sink to make it work, but seems ok now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants