-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Use pkg config udevdir #4126
Use pkg config udevdir #4126
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -1370,27 +1370,55 @@ if(UNIX AND NOT APPLE) | |||||
) | ||||||
|
||||||
option(INSTALL_USER_UDEV_RULES "Install user udev rule file for USB HID and Bulk controllers" ON) | ||||||
if (INSTALL_USER_UDEV_RULES) | ||||||
install( | ||||||
FILES | ||||||
"${CMAKE_CURRENT_SOURCE_DIR}/res/linux/mixxx-usb-uaccess.rules" | ||||||
DESTINATION | ||||||
"${MIXXX_INSTALL_DATADIR}/udev/rules.d" | ||||||
) | ||||||
install(CODE " | ||||||
message(STATUS \"Important Note: Installation of udev rules\n\" | ||||||
\"The udev rule file for USB HID and Bulk controller permissions will be\n\" | ||||||
\"installed to:\n\" | ||||||
\" ${CMAKE_INSTALL_PREFIX}/${MIXXX_INSTALL_DATADIR}/udev/rules.d.\n\" | ||||||
\"If you are installing Mixxx from source for your own use, copy\n\" | ||||||
\"mixxx-usb-uaccess.rules to /etc/udev/rules.d/ and run:\n\" | ||||||
\" udevadm control --reload-rules && udevadm trigger\n\" | ||||||
\"as root to load the rules.\n\" | ||||||
\"If you are building a package for a distribution, the correct directory for\n\" | ||||||
\"system rules is either /lib/udev/rules.d (e.g. Debian, Fedora) or\n\" | ||||||
\"/usr/lib/udev/rules.d (e.g. Arch Linux) with an appropriate priority prefix.\n\" | ||||||
\"Adjust your package script accordingly and set -DINSTALL_USER_UDEV_RULES=OFF\") | ||||||
") | ||||||
if(INSTALL_USER_UDEV_RULES) | ||||||
set(MIXXX_UDEVDIR "${MIXXX_INSTALL_DATADIR}/udev") | ||||||
if (CMAKE_INSTALL_PREFIX STREQUAL "/usr") | ||||||
find_package(PkgConfig) | ||||||
if (PKG_CONFIG_FOUND) | ||||||
pkg_check_modules( PKGCONFIG_UDEV udev) | ||||||
if (PKGCONFIG_UDEV_FOUND) | ||||||
execute_process( | ||||||
COMMAND ${PKG_CONFIG_EXECUTABLE} --variable=udevdir udev | ||||||
OUTPUT_VARIABLE PKGCONFIG_UDEVDIR | ||||||
OUTPUT_STRIP_TRAILING_WHITESPACE | ||||||
) | ||||||
if(PKGCONFIG_UDEVDIR) | ||||||
file(TO_CMAKE_PATH "${PKGCONFIG_UDEVDIR}" MIXXX_UDEVDIR) | ||||||
endif() | ||||||
Comment on lines
+1389
to
+1391
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Are you sure that PKGCONFIG_UDEVDIR is not an absolute path outside CMAKE_INSTALL_PREFIX? Mixxx mustn't install anything outside the chosen prefix under any circumstances. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It does not:
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. And this is certainly the case on all systems? So returning a relative path instead of an absolute one is guaranteed by pkg-config? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't know. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
In case of udevdir it is an exception. The rules files have to be installed at the common folder returned by pkg-config IF Mixxx is installed in the system location "/usr". This should happens only in the packaging case. In all other case the udevdir is useless and the rules file is installed under our fall back location .../share/mixxx/udev/rules.d/mixxx-usb-uaccess.rules as before. This should make all hacks in the packaging scripts obsolete. Do we know a distro where this assumption is void? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
What would be wrong? Have you read the special case section at: https://cmake.org/cmake/help/v3.15/module/GNUInstallDirs.html?highlight=gnuinstalldirs#special-cases
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ah Ok, so we need to check how debuild uses CMake There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What does PC return for udevdir on arch? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Arch does not use There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Cool, so it should work for all major distros at least |
||||||
endif() | ||||||
endif() | ||||||
endif() | ||||||
if (MIXXX_UDEVDIR STREQUAL "${MIXXX_INSTALL_DATADIR}/udev") | ||||||
install( | ||||||
FILES | ||||||
"${CMAKE_CURRENT_SOURCE_DIR}/res/linux/mixxx-usb-uaccess.rules" | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
This file needs to be renamed to have the correct priority. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is the path where we install the file to the data directory. I have not renamed it to not break existing packaging scripts. To use the file the user can move and rename it as desired. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That defeats the purpose. The packager should not have to do anything besides the CMake install step. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Here we are in the branch that is not for packagers. In the packager's branch the file is renamed. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is unnecessarily complicated. Please simply rename the file. Packagers have already said that is not a problem. At most it is changing a single line of code for them. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This place is not for packagers! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can't we just rename it in There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why is this file even installed to somewhere it has no effect? I think we should just show a warning that the file has not been installed. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It makes sense to have this file as part of the installer and move it yourself. FWIW it's actually a bit unexpected that just having mixxx installed messes around with your system permissions instead of copying the file yourself, but in this special case it's not an issue because the security implications of giving all users permission to access HID DJ controllers are small :D |
||||||
DESTINATION | ||||||
"${MIXXX_UDEVDIR}/rules.d" | ||||||
) | ||||||
install(CODE " | ||||||
message(STATUS \"Important Note: Installation of udev rules\n\" | ||||||
\"The udev rule file for USB HID and Bulk controller permissions have been\n\" | ||||||
\"installed to:\n\" | ||||||
\" ${MIXXX_UDEVDIR}/rules.d.\n\" | ||||||
\"If you are installing Mixxx from source for your own use, copy\n\" | ||||||
\"mixxx-usb-uaccess.rules to /etc/udev/rules.d/ and run:\n\" | ||||||
\" udevadm control --reload-rules && udevadm trigger\n\" | ||||||
\"as root to load the rules.\n\" | ||||||
\"If you are building a package for a distribution, the correct directory for\n\" | ||||||
\"system rules is either /lib/udev/rules.d (e.g. Debian, Fedora) or\n\" | ||||||
\"/usr/lib/udev/rules.d (e.g. Arch Linux) with an appropriate priority prefix.\n\" | ||||||
\"Adjust your package script accordingly and set -DINSTALL_USER_UDEV_RULES=OFF\") | ||||||
") | ||||||
else() | ||||||
install( | ||||||
FILES | ||||||
"${CMAKE_CURRENT_SOURCE_DIR}/res/linux/mixxx-usb-uaccess.rules" | ||||||
DESTINATION | ||||||
"${MIXXX_UDEVDIR}/rules.d" | ||||||
RENAME | ||||||
"69-mixxx-usb-uaccess.rules" | ||||||
) | ||||||
endif() | ||||||
endif() | ||||||
endif() | ||||||
|
||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure this will work on e.g. nixOS, as they have a very different directory structure as packages are installed to the
/nix
directory (but I also don't really know how they handle udev rule files, better ask someone who knows!).Can we not check whether
CMAKE_INSTALL_PREFIX
does not match/usr/local
instead?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The install prefix can also be
~/.local or /opt or wherever the user thinks it is correct.
So it is IMHO more reasonable to check for the system path that corospods to the system udev dir.
We can extend the list of suitable packaging install prefixes on demand.