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

external: update miniupnpc 2.2.8 #9367

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

0xFFFC0000
Copy link
Collaborator

@0xFFFC0000 0xFFFC0000 commented Jun 13, 2024

Fix and improve existing CMake script.

Fixes: #9359

Related: #9366

1. LINKS flag, will link publicly the libraries provided.
2. PRIVATE_LINKS flag, will link privately the libraries provided.
3. INCLUDES flag, will includes publicly the dirs provided.
4. PRIVATE_INCLUDES flag, will include privately the libraries provided.
@nahuhh
Copy link

nahuhh commented Aug 11, 2024

Fix and improve existing CMake script.

Fixes: #9359

Requires: #9366

9366 is included in this PR. Can close 9366

@wizeguyy
Copy link

@0xFFFC0000 any update on this?

@0xFFFC0000
Copy link
Collaborator Author

0xFFFC0000 commented Aug 20, 2024

@0xFFFC0000 any update on this?

It is ready, has been since its release. Needs reviews.

@@ -35,8 +35,13 @@
# ...except for FreeBSD, because FreeBSD is a special case that doesn't play well with
# others.

if(NOT MSVC)
add_compile_options(-D_GNU_SOURCE)
Copy link
Contributor

Choose a reason for hiding this comment

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

Is this needed since we add _GNU_SOURCE to compile options in the root CMakeLists.txt?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Yes, since we add it to CMAKE_C_FLAGS [1] and it does not pass it to projects added via add_subdirectory. It fixes this build issue [2].

  1. https://github.com/monero-project/monero/blob/a1dc85c5373a30f14aaf7dcfdd95f5a7375d3623/CMakeLists.txt#L910C7-L910C20
  2. Compilation errors on gcc 14.1.1 #9359

Copy link
Collaborator

@selsta selsta left a comment

Choose a reason for hiding this comment

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

This breaks gitian builds, because the miniupnpc submodule update requires CMake 3.14 and gitian builds use 3.10

@nahuhh
Copy link

nahuhh commented Sep 28, 2024

@selsta i notice that wownero merged this

https://codeberg.org/wownero/wownero/commit/5fe3cf2349ae277f1c606332eb16916a640e1e48

maybe broken there too. Didnt check with them. Just thought i'd mention

@selsta
Copy link
Collaborator

selsta commented Sep 28, 2024

@nahuhh wowario reported it to me :)

@0xFFFC0000
Copy link
Collaborator Author

The problem is they have enforced 3.14 here [1]. Give me a little bit of time to think about this. It is dilemma, they are strictly requiring 3.14, and at the same time we don't want 3.14.

https://github.com/miniupnp/miniupnp/blob/master/miniupnpc/CMakeLists.txt#L1

@selsta selsta mentioned this pull request Dec 14, 2024
@tobtoht
Copy link
Collaborator

tobtoht commented Dec 18, 2024

Guix has CMake 3.24.2, however considering that miniupnpc is packaged everywhere, and we don't apply any patches, I don't see why we would need to keep this dependency as a submodule. I would prefer moving miniupnpc to depends (#9273) for sake of consistency. This approach also speeds up recursive checkouts and saves package maintainers the effort of unvendoring this library.

I would also be in favor of simply removing miniupnpc since it has a long history of vulnerabilities and isn't very actively maintained.

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

Successfully merging this pull request may close these issues.

Compilation errors on gcc 14.1.1
6 participants